<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          一份 ElementUI 問題清單

          共 6498字,需瀏覽 13分鐘

           ·

          2021-10-24 10:57

          點擊上方 前端瓶子君,關注公眾號

          回復算法,加入前端編程面試算法每日一題群

          1、form 下面只有一個 input 時回車鍵刷新頁面

          原因是觸發(fā)了表單默認的提交行為,給el-form 加上@submit.native.prevent就行了。

          <el-form inline @submit.native.prevent>
            <el-form-item label="訂單號">
              <el-input
                v-model="query.orderNo"
                :placeholder="輸入訂單號查詢"
                clearable
                @keyup.enter.native="enterInput"
              />

            </el-form-item>
          </el-form>
          復制代碼

          2、表格固定列最后一行顯示不全

          image.png

          這種情況有時在寬度剛好處于臨界值狀態(tài)時會出現(xiàn)。因為固定列是獨立于表格body動態(tài)計算高度的,出現(xiàn)了固定列高度小于表格高度所以造成最后一行被遮擋。

          // 設置全局
          .el-table__fixed-right {
            height100% !important;
          }
          復制代碼

          3、氣泡確認框文檔里的confirm事件不生效

          版本:element-ui: "2.13.2", vue: "2.6.10"

          // 將confirm改為onConfirm
          @onConfirm="onDeleteOrder(row.id)"
          復制代碼

          4、輸入框用正則限制但綁定值未更新

          看到項目里有下面這么一段代碼:

          <el-input 
            v-model="form.retailMinOrder" 
            placeholder="請輸入" 
            onkeyup="value=value.replace(/[^\d.]/g,'')" 
          />

          復制代碼

          這樣做雖然輸入框的顯示是正確的,但綁定的值是沒有更新的,將 onkeyup 改為 oninput 即可。

          • PS:經評論區(qū)的兄弟指正,輸入中文后 v-model 會失效,下面的方式更好一點:
          <el-input 
            v-model="form.retailMinOrder" 
            placeholder="請輸入" 
            @keyup.native="form.retailMinOrder=form.retailMinOrder.replace(/[^\d.]/g,'')"
          />

          復制代碼

          5、去除type="number"輸入框聚焦時的上下箭頭

          image.png
          /* 設置全局 */
          .clear-number-input.el-input::-webkit-outer-spin-button,
          .clear-number-input.el-input::-webkit-inner-spin-button {
            margin0;
            -webkit-appearance: none !important;

          .clear-number-input.el-input input[type="number"]::-webkit-outer-spin-button,
          .clear-number-input.el-input input[type="number"]::-webkit-inner-spin-button {
            margin0;
            -webkit-appearance: none !important;
          }
          .clear-number-input.el-input {
            -moz-appearance: textfield;

          .clear-number-input.el-input input[type="number"] {
            -moz-appearance: textfield;
          }
          復制代碼
          <el-input type="number" class="clear-number-input" />
          復制代碼

          6、只校驗表單其中一個字段

          在一些用戶注冊場景中,提交整個表單前有時候我們會做一些單獨字段的校驗,例如發(fā)送手機驗證碼,發(fā)送時我們只需要校驗手機號碼這個字段,可以這樣做:

          this.$refs['form'].validateField('mobile', valid => {
            if (valid) {
              // 發(fā)送驗證碼
            }
          })
          復制代碼

          如果需要多個參數(shù),將參數(shù)改為數(shù)組形式即可。

          7、彈窗重新打開時表單上次的校驗信息未清除

          有人會在open時在$nextTick里重置表單,而我選擇在關閉時進行重置。

          <el-dialog @close="onClose">
            <el-form ref="form">
            </el-form>

          </el-dialog>

          // 彈窗關閉時重置表單
          onClose() {
            this.$refs['form'].resetFields()
          }
          復制代碼

          8、表頭與內容錯位

          網上也有其他一些辦法,但我記得對我沒什么作用,后來我是用下面這個辦法:

          // 全局設置
          .el-table--scrollable-y .el-table__body-wrapper {
           overflow-y: overlay !important;
          }
          復制代碼

          9、表單多級數(shù)據(jù)結構校驗問題

          <el-form :model="form">
            <el-form-item label="部門" prop="dept"></el-form-item>
            <el-form-item label="姓名" prop="user.name"></el-form-item>
          </el-form>
          復制代碼
          rules: {
            'user.name': [{ requiredtruemessage'姓名不能為空'trigger'blur' }]
          }
          復制代碼

          10、表格跨分頁多選

          看到項目里有小伙伴手動添加代碼去處理這個問題,其實根據(jù)文檔,只需加上row-key和reserve-selection即可。

          <el-table row-key="id">
            <el-table-column type="selection" reserve-selection></el-table-column>
          </el-table>
          復制代碼

          11、根據(jù)條件高亮行并去除默認hover顏色

          <el-table :row-class-name="tableRowClassName">
          </el-table>

          tableRowClassName({ row }) {
            return row.status === 2 ? 'highlight' : ''
          }

          // 設置全局
          .el-table .highlight {
            background-color: #b6e8fe;
            &:hover > td {
              background-color: initial !important;
            }
            td {
              background-color: initial !important;
            }
          }
          復制代碼

          12、表單不想顯示label但又想顯示必填星號怎么辦

          // label給個空格即可
          <el-form>
            <el-table>
              <el-table-column label="名稱">
                <template>
                  <el-form-item label=" ">
                     <el-input placeholder="名稱不能為空" />
                  </el-form-item>
                </template>
              </el-table-column>
            </el-table>
          </el-form>
          復制代碼

          13、table 內嵌 input 調用 focus 方法無效

          <el-table>
            <el-table-column label="名稱">
              <template>
                <el-input ref="inputRef" />
              </template>
            </el-table-column>
          </el-table>

          // 無效
          this.$refs['inputRef'].focus()
          this.$refs['inputRef'][0].focus()
          this.$refs['inputRef'].$el.children[0].focus()

          // 有效
          <el-input id="inputRef" />
          document.getElementById('inputRef').focus()
          復制代碼

          14、表格內容超出省略

          看到有小伙伴在代碼里自己手動去添加CSS來實現(xiàn),害,又是一個不看文檔的反面例子,其實只要加個show-overflow-tooltip就可以了,還自帶tooltip效果,不香嗎?

          image.png
          <el-table-column label="客戶名稱" prop="customerName" show-overflow-tooltip>
          </el-table-column>
          復制代碼

          15、el-tree 展開/收起所有節(jié)點

          <el-tree ref="tree"></el-tree>

          expandTree(expand = true) {
            const nodes = this.$refs['tree'].store._getAllNodes()
            nodes.forEach(node => {
              node.expanded = expand
            })
          }
          復制代碼

          16、哪天想起什么或遇到什么再更新。。。


          關于本文

          作者:8號的凌晨4點

          https://juejin.cn/post/6981083988286767117


          最后

          歡迎關注【前端瓶子君】??ヽ(°▽°)ノ?
          回復「算法」,加入前端編程源碼算法群,每日一道面試題(工作日),第二天瓶子君都會很認真的解答喲!
          回復「交流」,吹吹水、聊聊技術、吐吐槽!
          回復「閱讀」,每日刷刷高質量好文!
          如果這篇文章對你有幫助,在看」是最大的支持
           》》面試官也在看的算法資料《《
          “在看和轉發(fā)”就是最大的支持
          瀏覽 45
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  青青草成人视屏 | 传媒-熊猫成人网 | 日本有码中文 | 欧美一级免费A片 | 人人看大箱交 |