JS常见知识点

Posted XW_Wong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS常见知识点相关的知识,希望对你有一定的参考价值。

1、写一个按照下面方式调用都能正常工作的 sum 方法

console.log(sum(2,3)); // Outputs 5
console.log(sum(2)(3)); // Outputs 5

解决方案

function sum() {
  var fir = arguments[0];
  if (arguments.length === 2) {
    return arguments[0] + arguments[1]
  } else {
    return function (sec) {
      return fir + sec;
    }
  }
}
sum(2)(5)

2、下面的代码会输出什么?为什么?

var arr1 = "john".split(‘‘); j o h n
var arr2 = arr1.reverse(); n h o j
var arr3 = "jones".split(‘‘); j o n e s
arr2.push(arr3);
console.log("array 1: length=" + arr1.length + " last=" + arr1.slice(-1));
console.log("array 2: length=" + arr2.length + " last=" + arr2.slice(-1));
  • reverse() 会改变数组本身,并返回原数组的引用。
  • slice() 方法可提取字符串的某个部分,并以新的字符串返回被提取的部分。
    stringObject.slice(start,end);
    arrayObject.slice(start,end);
    • start和end如果是负数,则该参数规定的是从字符串的尾部开始算起的位置。也就是说,-1 指字符串的最后一个字符,-2 指倒数第二个字符,以此类推。 

3、下面的代码会输出什么?为什么?

1 console.log(1 + "2" + "2");   
2 console.log(1 + +"2" + "2");
3 console.log(1 + -"1" + "2");
4 console.log(+"1" + "1" + "2");
5 console.log( "A" - "B" + "2");
6 console.log( "A" - "B" + 2);

  我们先来看几条规则:

  • 数字字符串之前存在数字中的正负号(+/-)时,会被转换成数字
    console.log("类型:"+(typeof ‘3‘)+" 内容为:"+‘3‘)      //类型:string 内容为:3
    console.log("类型:"+(typeof +‘3‘)+" 值为:"+(+‘3‘))    //类型:number 值为:3
    console.log("类型:"+(typeof -‘3‘)+" 值为:"+(-‘3‘));  //类型:number 值为:-3
  • (字符串 + 数字) 或者 (数字+字符串) ,都得到一个字符
    console.log(5 + ‘A‘);    //5A 
    console.log(‘A‘ + 5);    //A5
    console.log(NaN + ‘A‘); //NaNA
    console.log(‘A‘ + NaN); //ANaN
  • 对于运算结果不能转换成数字的,将返回 NaN
    console.log(‘a‘ * ‘sd‘); //NaN
    console.log(‘A‘ - ‘B‘); // NaN
  • 其他的一些例子
    console.log(‘-3‘ - 2 + 1);    //-4   number类型
    console.log( 3 + ‘-2‘ + 1);   //3-21 string类型
    console.log( 3 - ‘-2‘ + 1);   //6    number类型
  • 也许我们已经有答案了
    1 console.log(1 + "2" + "2");      // "122"
    2 console.log(1 + +"2" + "2");     // "32"
    3 console.log(1 + -"1" + "2");     // "02"
    4 console.log(+"1" + "1" + "2");   //"122"
    5 console.log( "A" - "B" + "2");  // "NaN2"
    6 console.log( "A" - "B" + 2);    //NaN

     (未完待续)

 

以上是关于JS常见知识点的主要内容,如果未能解决你的问题,请参考以下文章

记录--九个超级好用的 Javascript 技巧

android小知识点代码片段

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

VSCode自定义代码片段——JS中的面向对象编程

VSCode自定义代码片段9——JS中的面向对象编程

js代码片段: utils/lcoalStorage/cookie