js常用小知识点

1、对象深监听

testObj:{
  handler(){
    this.setShowObj();
  },
  deep:true,
  immediate:true,
}

2、网页打断点

按F12打开,点到resources面板,然后按F8

3、定时器

_than.setIntervalId = window.setInterval(function () {
if (_than.percentage < 99) {
_than.percentage = _than.percentage + 1;
}
}, 300);

结束:

clearTimeout(_than.setIntervalId);

4、禁止点击回车enter提交表单

项目中出现的现象:鼠标放到输入框中,点击回车,会重新刷新页面,请求local接口

<el-input v-model="telNum" placeholder="临时测试" onkeydown="if(event.keyCode==13)return false;" style="width:280px"></el-input>

回车执行自己的方法:

<el-input placeholder="请输入搜索关键字" v-model="filterKey" @keydown.native.enter.stop="filterEmpData(filterKey)">
        <i slot="prefix" class="el-input__icon el-icon-search"></i>
 </el-input>
/**搜索数据 */
function filterEmpData(val) {
var event = window.event;
event.stopPropagation();
event.preventDefault();
//自己的操作
}

5、日期格式化

function dateFormat(fmt, date) {
    var o = {
        "M+": date.getMonth() + 1,                 //月份
        "d+": date.getDate(),                    //日
        "H+": date.getHours(),                   //小时
        "m+": date.getMinutes(),                 //分
        "s+": date.getSeconds(),                 //秒
    };
    if (/(y+)/.test(fmt))
        fmt = fmt.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length));
    for (var k in o)
        if (new RegExp("(" + k + ")").test(fmt))
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
    return fmt;
}

使用:dateFormat(“yyyy-MM-dd”,new Date())

6、JS中拼接两个数组

var newArr = arr.concat(arr2);

7、子字符串截取

stringObject.substring(start,stop)

8、JSON和对象转换

JSON转对象

this.jsonObj= JSON.parse(this.jsonStr);

对象转JSON

this.jsonStr = JOSN.stringify(this.jsonObj);

9、监听不到数组变化或对象属性的变化

数组中为对象,通过下标改变某个对象的某个属性,有的时候监听不到
解决:

var tmp = [{id:1,name:'11'},{id:2,name:'11'}]

改变下标为0的name:

tmp[0].name='aaa';  
var ss = tmp[0];  
this.$set(tmp,0,ss)   //(数组,下标,该下标的对象)

对象:

this.$set(this.before,'adjustType',this.adjustDictData[i].name) //(对象,属性,属性值)

10、js对象属性变化页面兼听不到

this.$forceUpdate();

11、纯JS修改样式

示例:

document.querySelector(".emp_info_div .el-tabs__nav-scroll").style.paddingLeft = '245px';

12、文本域显示内容情况下换行

<div v-html="remark.replace(/(\r)|(\r\n)|(\n)/g, '<br/>')" ></div>

13、Map操作(对当前数组整理得到新数组)

 var arr = [1,2,3].map(function(number, index){
      return number * number + index
     })
     // arr 为 [1, 5, 11] 对当前数组数据进行整理得到一个映射的新数组

14、Filter(过滤得到符合条件的数组)

   var arr = [1,2,3,4,5].filter(function(item, index){
         return item > 3
       })
     // arr 为 [4, 5] 对当前数组按条件过滤,取return为true的所有项得到一个新数组。对原数组项的值引用

15、Sort(排序,返回true会交换位置)

 var arr = [{name: 'fir',value: 5},
 			{name: 'sec',value: 7},
 			{name: 'thi',value: 6}]
 			.sort(function(a, b){
                    return a.value - b.value
            })
 // arr 为 [{name: 'fir',value: 5},
 			{name: 'sec',value: 6},
 			{name: 'thi',value: 7}]
 //遍历所有项获得一个按指定方法排序的新数组 return true时会交换前后项的位置
//对原数组项的值引用

16、Slice(取指定下标之间得到一个新数组)

   var arr = [1,2,3].slice(1)   // arr 为 [2, 3]
   var arr = [1,2,3].slice(0,2) // arr 为 [1, 2]
                //取指定下标之间的项得到一个新数组
                //不传结束位置时默认截取到结束
//对原数组项的值引用

17、Splice(改变原数组得到删除项所组成的新数组)

   var arr = [1,2,3]
   var deleteItems = arr.splice(0, 2, ['a']) 
   // arr 为 ['a', 3] deleteItems 为 [1, 2]
   //改变原数组并且得到删除项所组成的新数组         
//对原数组项的值引用

18、Some(返回Boolean相当于判断数组中是否存在否元素)

var res = [1,2,3].some(function(number, index){ 
							return number > 4 
						}) // res 为false 
 //有true 即中止遍历 
 //等价于 var arr = [1,2,3];
 // var res = true for (var i = 0; i < arr.length;i++) { if (arr[i] > 0) res = true break }  

19、Find

  var res = [1,2,3].find(function(number, index){
                    return nubmer > 2
                }) // res 为 3
 // 有true 即中止遍历, 返回数组中第一个符合条件的项,没有则返回null

20、数组转为字符串

var str = [11,22,33].join(',')
// str为"11,22,33"

21、Cookie存储问题

Cookie.set('test1', this.test1, { expires: 30 })

//Cookie会长度溢出,使用localStorage来存储
// Cookie.set('reportContent', res.data.data.result.reportContent, { expires: 30 })
localStorage.setItem('reportContent', res.data.data.result.reportContent);

if(!Cookie.get('test1')) return
//若有cookie则从cookie中获取值
var _than = this;
_than.isCookie = true;
_than.test1= Cookie.get('test1') // cookieData[0].split("=")[1];
//Cookie会长度溢出,使用这种方法
_than.reportContent = JSON.parse(localStorage.getItem('reportContent')) 

持续更新中…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值