我是靠谱客的博主 清秀蜗牛,最近开发中收集的这篇文章主要介绍Web前端复习——Javascript复习(数值转换+运算符),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

1、数值转换

两大类:隐式转换、强制转换

A.隐式转换

特点:无需程序员干预,js会自动完成的类型转换。。

在这里,仅讨论“+”运算符中的隐式转换:2句

算数运算中,一切类型都隐式转为Number类型,在进行计算。

比如——

"2"——2   true/false——1/0

特例: 

在“+”运算中,若运算符的任意一边出现字符串,则双方都自动转换为“字符串”类型。此外,“+”运算符也会变为字符串的拼接。


总结——仅影响表达式的运算结果,不影响变量中存储的实际值。


B.强制转换

(1)任意类型——String

var str = x.toString();

    js中,一切数据都有toString方法

var str = String(x);——隐式转换

何时使用?

   程序在需要时,会自动调用。


(2)任意类型——Number

String to Number——2种

第一种:var n = parseInt(str);

原理:从str开始位置逐个读取每个字符,直到碰到第一个不是数字的字符时,停止读取;

会自动忽略开头碰到的空格。

比如——

var width = "12px";

width +"2px" ——“12px2px”

    (1)Number(width) + Number("2px")——NaN

    (2)parseInt(width) + parseInt("2px")

"12px"              "2px"

   12      2   ——14

    此时, width = 14+ "px";

    var money = $40;——NaN


第二种:var n = parseFloat(str);

原理和parseInt完全一致,但是parseFloat,只认定第一个小数点

比如——

parseFloat("34.56"); ——34.56

parseFloat("34.56.78");——34.56


Number(x)  VS parseInt(str)

比如——

Number("12px")——NaN

parseInt("12px")  ——12

        string to Number  ——parseInt


Number(true)——1

parseInt(string(true))——parseInt("true")——NaN

x to Number——Number()


(3)任意类型——Boolean

var bool = Boolean(x);  ——隐式转换

当x= ""/ NaN /undefined /null /0   Boolean(x)——false

其余时,为true


类型转换函数总结:

(1)Number——String

     Boolean——String

x.toString()/String


(2)String——Number

parseInt(str)

parseFloat(str)

(3)String——Boolean

     Number——Boolean

Boolean(x)

(4)Boolean——Number

Number(x)


2、运算符和表达式

程序:让计算机按照人的想法去执行任务。

运算符:程序中模拟人的思维运算或判断的符号

运算符分类——

(1)算数运算符:“+”、“-”、“*”、“/”、“%”(取余)、“++”、“--”

“%”作用:a、判断奇偶数(n%2)

   b、确保一个运算的结果,不超过某个最大值(除数)


“++”使用:

a、情况1——“n++”,先n赋值,再运算++

var n=3;
console.log(n++);
//3
console.log(n);
//4

b、情况2——“++n”,先运算++,再n赋值

var n=3;
console.log(++n);
//4
console.log(n);
//4

总结:无论“n++”,还是“++n”,最后“n”的结果是相同的。


(2)关系运算符

将两个值进行比较:>、<、>=、<=、==、!=

返回true/false

隐式转换:将所有类型都转为number类型,再比较。

特殊情况:3种

a、两字符串比较

原理:依次PK每一位字符的unicode编号(只要有一位执法,分出大小,就不再比较)

比如:"3">"10"——true

      "Smith">"Scott"——true

                  "m"   "c"

   109   99

      "张东">"张无忌"——false

  "东"   "无"

                 19996    26080


b、NaN:NaN和任何数据做大小或等于比较,永远返回false

NaN和任何数据做**不等于**比较,永远返回true

isNaN(num):专门判断num是否是NaN

如果是NaN,返回true,否则返回false

When:今后只要判断一个数值是否是数字或是否是被转为数字,都用isNaN。

如果是数字,返回false,否则,返回true。


c、undefined VS null

undefined==null    true

===:全等,首先保证数据类型要相同,其次再比较数值是否相等。

不带隐式转换。

When:只要不希望关系运算中自动隐式转换时。


(3)逻辑运算符

返回值只有两个:true、false

a && b —— true true   — true

a || b —— true 任意x  — true

笔试题——

var n=10;
var m=10;
var r=n++>10 && ++m>10;
// n++>10 || ++m>10
console.log(r);
console.log(n);
console.log(m);


(4位运算符——2个

左移:n<<m  将n的二进制,左移m位;

比如——1<<3  ——1*  2的3次方

右移:n>>m  将n的二进制,右移m位

比如——64>>3 ——64/ 2的3次方  ——8


(5)赋值运算符

5个:+=、-=、*=、/=、%=

(6)三元运算符

a ?  b : c

例如——计算“平年”还是“闰年”

year%4 ==0 && year%100 !=0 || year%400 ==0 ? "是平年":"是闰年"

 

最后

以上就是清秀蜗牛为你收集整理的Web前端复习——Javascript复习(数值转换+运算符)的全部内容,希望文章能够帮你解决Web前端复习——Javascript复习(数值转换+运算符)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部