开发时遇到的问题以及一些实用小技巧(vue)

前言

最近突然想总结一下开发中所遇到的问题和一些小方法,会一直更新直到不在做开发!

(附:一个vue3的学习社区非常不错?。?/a>)

1.数组判断长度和元素相等

  isContained =(a, b)=>{
    if(!(a instanceof Array) || !(b instanceof Array)) return false;
    if(a.length != b.length) return false;
    for(var i = 0, len = b.length; i < len; i++){
       if(a.indexOf(b[i]) == -1 || b.indexOf(a[i]) == -1) {
         return false;
       }
     }
     return true;
    }
    arr1 = [1,2,3,4,'obj'];
    arr2 = [4,3,2,1,'obj'];
    alert(isContained(arr1,arr2));

2.elementUI 使用心得

双击表格
<el-table @row-dblclick="dbSelected">
</el-table>
el-table的属性show-header,默认值是true,也就是默认有表头,即使我们没有定义,也会默认添加表头。

(2). Tree 树形控件默认勾选指定的子节点

const nodesList = [ 1, 5, 7, 8, 9 ]  //后端返回的已勾选的项 通过字段判断出id是选中的
this.$nextTick(() => {
    const nodes = []
    nodesList.forEach(item => {
        const node = this.$refs.tree.getNode(item); // 获取所有的节点
        if (node.isLeaf) { //关键,过滤掉不是叶子节点的
            nodes.push(item)
        }
    })
    this.$refs.tree.setCheckedKeys(nodes,true) //通过 id 设置目前勾选的节点
})

(3). 隐藏table的滚动条(注意:隐藏后横向滚动条也不会出现 所以以后除了打游戏都应该变成Macbook的触控板 这才是发展方向)

滚动隐藏
/deep/.el-table {
  .el-table__body-wrapper{
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .el-table__body-wrapper::-webkit-scrollbar{
    width: 0;
  }
  .el-table__body-wrapper::-webkit-scrollbar-thumb {
    width: 0;
  }
}

(4). InputNumber 计数器的问题

问题描述:
1:在父组件把数据传入到子组件:
2:子组件中使用 el-input-number
3:传入的内容为数量 1 或者其它,
数据可以从父组件传入到子组件,
但是el-input-number 里面不管是按 + 还是 -
只能变成 0 或者2,
无法在进行增加了。

<el-input-number v-model="scope.row.num" :precision="0" :min="1" label="" @change="changeVal($event)">

changeVal() {
    this.$forceUpdate();// 解决办法
}

(5). el-table 组件 表头右侧多出一部分

image.png

原因:
所有 el-table-column 都设了宽度,当内容超出高度滚动条出现,表头多出一列滚动条上方的占位
解决:
将 th.gutter 隐藏或将 th.gutter 移动到滚动条上方

/* 隐藏 不兼容iE */
th.gutter {
  display: initial;
}
 
/* 移动  兼容IE*/
th.gutter {
  background-color: #f1f1f1;
  position: absolute;
  height: 100%;
  right: 0;
}
/* vue 使用 scoped 需要 /deep/ 深度作用 */
div /deep/ th.gutter {
  display: initial;
}

(6). 遇到耗时操作使用loading的时候 不会有效果

     // 使用setimeout 将耗时操作放到setimeout里 
     // 将loading关闭的方法也放入setimeout里
    setTimeout(() => {

    }, 100);

(7). el-table底部空白,el-table__body-wrapper is-scrolling-left元素高度计算错误

     // 设置表格body的高度
    .el-table__body-wrapper {
      // 减去的是表格header的高度
      height: calc(100% - 40px) !important;
    }

(8). 多个dialog展示的时候会出现遮罩层一直存在问题

     // 设置表格body的高度
    .el-table__body-wrapper {
      // 减去的是表格header的高度
      height: calc(100% - 40px) !important;
    }

3.对象数组筛选 并 合并 指定字段完全相同进行项合并

mergerData(arr) {
      let result = new Map()
      if (arr.length > 1) {
        return arr.reduce((list, item)=>{
          let key = item.fulfillType + item.currencyCode; // 这里是你需要多少相同字段拼接成字符串 作为标识
          if(result.has(key)){
            // 如果字段相同 进行需要合并字段合并或者相加 逻辑处理
            result.get(key).amount = 
              new Decimal(result.get(key).amount).add(item.amount).toNumber()
            result.get(key).fulfillAmount =
              new Decimal(result.get(key).fulfillAmount).add(item.fulfillAmount).toNumber()
          }else{
            // 如果不相同则加入结果
            let data = {...item}
            list.push(data)
            result.set(key, data)
          }
          return list
        }, []);
      } else {
        return arr
      }
    },

4. 对比两个数组 如果不同项进行合并

var arr = [
        {id:'9999'},
        {id:'8888'},
        {id:'7777'},
        {id:'5555'},
        {id:'4444'},
    ]
    var brr = [
        {id:'8888'},
        {id:'7777'},
        {id:'2222'},
        {id:'3333'},
    ]
    let catArr = []
    for (let i= 0; i< arr.length; i++) {
        for (let j = 0; j < brr.length; j++) {
            if(arr[i].id == brr[j].id ){ 
                // 如需替换
                // arr[i] = brr[j]
                break
            }
            if( j === brr.length-1 ){
                catArr.push(arr[i] )
            }
        }
    }
    brr.concat(catArr)
    console.log(brr)

5.如何将大型项目从 Vue 2 迁移到 Vue 3

How to Migrate a large project from Vue 2 to Vue 3

6.display:-webkit-box;在IE浏览器中不兼容问题

一般做文字仅显示两行 会这样做

span{
    overflow:hidden; 
    text-overflow:ellipsis;
    display:-webkit-box; 
    -webkit-box-orient:vertical;
    -webkit-line-clamp:2; 
}

但是display:-webkit-box;在IE浏览器中不兼容

   // 解决方案:注意省略号不会存在 需要自己写样式
  加一句display: -ms-flexbox;代码就可以兼容IE了(只能兼容到IE10),
       display: -webkit-box; (Chrome 4+, Safari 3.1, iOS Safari 3.2+)
       display: -moz-box; (Firefox 17-)
       display: -webkit-flex; (Chrome 21+, Safari 6.1+, iOS Safari 7+, Opera 15/16)
       display: -moz-flex; (Firefox 18+ )
       display: flex;(Chrome 29+, Firefox 22+, IE 11+, Opera 12.1/17/18, Android 4.4+ 

7.vue中change事件的冒泡阻止

在Vue中,如果想阻止点击事件冒泡,可以直接使用 .stop 修饰符即可

<div @click="divClick">
    <button @click.stop="btnClick">按钮</button>
</div>

像上面这样,点击按钮时就不会触发到父元素的 divClick 事件。
当我们试着给 change 事件加上 .stop 修饰符时,发现并未起到阻止冒泡的作用,父元素 的 点击 事件还是执行了。
这个时候,我们可以通过使用原生事件 event.stopPropagation() 来解决这个问题。

stepperChange() {
  event.stopPropagation();  // 阻止事件冒泡
  console.log('change事件触发');
}

像上面这样在方法中加入一行代码,就可以了。

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容