社区脚本中心 → 浏览:帖子主题
* 帖子主题:js 高级写法
pojin (ID: 1)
头衔:论坛坛主
等级:究级天王[荣誉]
积分:1301
发帖:99
来自:保密
注册:2022-08-28 23:20:57
造访:2025-03-23 21:18:24
[ 第 1 楼 ] 回复
一般写法    优化
取整(不四舍五入)   

var a='12.534324'

parseInt(a,10);

Math.floor(a);

a>>0;      //12
   

~~a;    //12

a|0;

 
取整(四舍五入)   

var a='12.534324'

Math.round(a);
num.toFixed(0)
    a+.5|0;  //13
未定义   

undefined; 

    void 0;      // 快
0[0];        // 略慢
布尔值短写法   

true; 

    !0; 
串连字符串   

var a='a',b=4,c='c';

''+a+b+c; 
    ''.concat(a, b, c);
字符串截取   

var str='apple'

str.charAt(0); 

    str[0]
获取数组是否存在元素    for循环    [1, 2, 3].indexOf(2);

二、优化嵌套的条件语句

可优化大量的ifelse  switch语句

before:

//method1
    if (color) {
        if (color === 'black') {
            printBlackBackground();
        } else {
            printYellowBackground();
        }
    }

//method2
    switch(color) {
        case 'black':
            printBlackBackground();
            break;
        default:
            printYellowBackground();
    }

//method3
    switch(true) {
        case (typeof color === 'string' && color === 'black'):
            printBlackBackground();
            break;
        case (typeof color === 'string' && color === 'yellow'):
            printYellowBackground();
            break;
    }

 
优化后

//method4
    var colorObj = {
        'black': printBlackBackground,
        'yellow': printYellowBackground
    };
    if (color in colorObj) {
      colorObj[color]();
    }

三、检查某对象是否有某属性

使用 hasOwnProperty和in

before:

var myObject = {
      name: '@tips_js'
    };
if (myObject.name) { }

after:

myObject.hasOwnProperty('name'); // true
'name' in myObject; // true

myObject.hasOwnProperty('valueOf'); // false, valueOf 继承自原型链
'valueOf' in myObject; // true

四、更简单的使用indexOf实现contains功能

before:

var someText = 'javascript rules';
if (someText.indexOf('javascript') !== -1) {
}

after:

!!~someText.indexOf('tex'); // someText contains "tex" - false

!!~someText.indexOf('java'); // - true

五、将有length属性的对象转化为数组

比如带有length属性的自定义对象,NodeList,parameters等。

转化:

var  arr  = { length : 2 , 0 : 'first' , 1 : 'second' };
1、Array. prototype . slice . call (arr) //["first", "second"]
2、Array.from(arr) //

["first", "second"]

六、获取DOM元素在父类中的索引

<ul>
    <li></li>
    <li onclick="getIndex()"></li>
</ul>
 
//js
 
function getIndex() {
  var evt = window.event;
   var target = evt.target;
   return [].indexOf.call(document.querySelectorAll('li'), target);// 返回1
}

七、判断类型  instanceof
   
let data = [1]
console.log(data instanceof Array) // true

八、if else 高级写法
   
if(a >=5){
alert(“你好”);
}
可以写成:
 
a >= 5 && alert("你好");代码:var attr = true && 4 && “aaa”;
那么运行的结果attr就不是简单的true或这false,而是”aaa”代码:var attr = attr || “”;这个运算经常用来判断一个变量是否已定义,如果没有定义就给他一个初始值,这在给函数的参数定义一个默认值的时候比较有用。
   
出个题:
假设对成长速度显示规定如下:
成长速度为5显示1个箭头;
成长速度为10显示2个箭头;
成长速度为12显示3个箭头;
成长速度为15显示4个箭头;
其他都显示都显示0各箭头。
用代码怎么实现?
用if,else:
var add_level = 0; 
 
if(add_step == 5){ 
    add_level = 1; 

else if(add_step == 10){ 
    add_level = 2; 

else if(add_step == 12){ 
    add_level = 3; 

else if(add_step == 15){ 
    add_level = 4; 

else { 
    add_level = 0; 

 
稍好些的switch
 
var add_level = 0; 
 
switch(add_step){ 
    case 5 : add_level = 1; 
        break; 
    case 10 : add_level = 2; 
        break; 
    case 12 : add_level = 3; 
        break; 
    case 15 : add_level = 4; 
        break; 
    default : add_level = 0; 
        break; 

如果需求改成:
成长速度为>12显示4个箭头;
成长速度为>10显示3个箭头;
成长速度为>5显示2个箭头;
成长速度为>0显示1个箭头;
成长速度为<=0显示0个箭头
那么用switch实现起来也很麻烦了。
那么你有没有想过用一行就代码实现呢?
ok,让我们来看看js强大的表现力吧:
 
var add_level = (add_step==5 && 1) || (add_step==10 && 2) || (add_step==12 && 3) || (add_step==15 && 4) || 0;  
 
更强大的,也更优的:
var add_level={'5':1,'10':2,'12':3,'15':4}[add_step] || 0;
 
第二个需求:
var add_level = (add_step>12 && 4) || (add_step>10 && 3) || (add_step>5 && 2) || (add_step>0 && 1) || 0;
2022-12-09 21:02:39 IP:已设置保密
pojin (ID: 1)
头衔:论坛坛主
等级:究级天王[荣誉]
积分:1301
发帖:99
来自:保密
注册:2022-08-28 23:20:57
造访:2025-03-23 21:18:24
[ 第 2 楼 ] 回复
更严谨的写法!!

!!的作用是把一个其他类型的变量转成的bool类型
   
typeof 5  //"number"
typeof !!5  //"boolean"
2022-12-09 21:02:48 IP:已设置保密
pojin (ID: 1)
头衔:论坛坛主
等级:究级天王[荣誉]
积分:1301
发帖:99
来自:保密
注册:2022-08-28 23:20:57
造访:2025-03-23 21:18:24
[ 第 3 楼 ] 回复
一、检查对象是否存在某属性( hasOwnProperty 和 in )

    let Object = { name: '' }
    //第一种 hasOwnProperty
    console.log(Object.hasOwnProperty('name')) //true
    //第二种 in
    console.log('name' in Object) //true

二、检查数组是否存在某属性(includes)

        includes可以检测NaN,indexOf不能检测NaN,includes内部使用了Number.isNaN对NaN进行了匹配

    const A = ['a', 'b', 'c', 'd']
    console.log(A.includes('a')) //true

三、更简单地使用indexOf实现是否存在元素(!!~)

    //原本写法
    var A = 'javaScript is a scripting language'
    if (A.indexOf('javaScript') !== -1) {
      console.log('存在') //存在
    }
    //现在写法
    console.log(!!~A.indexOf('javaScript')) //true

四、将带有length属性的对象转化为数组(Array.prototype.slice.call和Array.from)

    var object = { length: 2, 0: 'apple', 1: 'pear' }
    //第一种
    const Arr1 = Array.prototype.slice.call(object)
    //第二种
    const Arr2 = Array.from(object)
    console.log(Arr1,Arr2) //[ 'apple', 'pear' ] [ 'apple', 'pear' ]

五、判断类型是否正确( instanceof )

    let arr = [1, 2, 3]
    let obj = { 0: 'apple', 1: 'pear', 2: 'banana' }
    console.log(arr instanceof Array, obj instanceof Array) //true false

六、合并数组和对象(扩展运算符...)

    const arr1 = [1, 2, 3, 4]
    const arr2 = [1, 3, 5, 7]
    let Arr = [...new Set([...arr1, ...arr2])]
    const obj1 = { a: 1, b: 2 }
    const obj2 = { c: 3, d: 4 }
    let Obj = { ...obj1, ...obj2 }
    console.log(Arr, Obj) //[ 1, 2, 3, 4, 5, 7 ] { a: 1, b: 2, c: 3, d: 4 }
2022-12-09 21:03:47 IP:已设置保密
分页: 1, 共 1 页
快速回复主题
账号/密码
用户: 没有注册?密码:
评论内容