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

简介: 开发时遇到的问题以及一些实用小技巧

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-tablebody-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-tablebody-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
}
},

  1. 对比两个数组 如果不同项进行合并
    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 &lt; 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事件触发');
}

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

相关文章
|
5天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
5天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
5天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
5天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
4天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
6天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
4天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
19天前
|
数据采集 监控 JavaScript
在 Vue 项目中使用预渲染技术
【10月更文挑战第23天】在 Vue 项目中使用预渲染技术是提升 SEO 效果的有效途径之一。通过选择合适的预渲染工具,正确配置和运行预渲染操作,结合其他 SEO 策略,可以实现更好的搜索引擎优化效果。同时,需要不断地监控和优化预渲染效果,以适应不断变化的搜索引擎环境和用户需求。
|
6天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
11天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发