JavaScript之全局函数详解

本文探讨了JavaScript的eval()函数在处理JSON字符串时的用法和注意事项,强调了eval的安全风险,并介绍了encodeURIComponent和decodeURI的作用,以及如何避免使用eval来处理JSON。此外,还提到了前端开发中常见的数值判断函数如isFinite和isNaN的用法。最后,分享了前端学习资源的相关信息。
摘要由CSDN通过智能技术生成

看一下在其他情况中,eval() 返回的结果:

eval(“2+3”) // 返回 5

var myeval = eval; // 可能会抛出 EvalError 异常

myeval(“2+3”); // 可能会抛出 EvalError 异常

可以使用下面这段代码来检测 eval() 的参数是否合法:

try {

alert(“Result:” + eval(prompt(“Enter an expression:”,“”)));

}catch(exception) {

alert(exception);

}

2.1.3.例子三(解析JSON字符串)

2.1.3.1.eval解析函数:

JSON 不允许包含函数,但你可以将函数作为字符串存储,之后再将字符串转换为函数。

var text = ‘{ “name”:“Runoob”, “alexa”:“function () {return 10000;}”, “site”:“www.runoob.com”}’;

var obj = JSON.parse(text);

obj.alexa = eval(“(” + obj.alexa + “)”);

document.getElementById(“demo”).innerHTML = obj.name + " Alexa 排名:" + obj.alexa();

2.1.3.2.JSON字符串转换为对象的两种方法

//将JSON字符串转为JS对象的方法一

var obj = JSON.parse(‘{ “name”:“runoob”, “alexa”:10000, “site”:“www.runoob.com” }’);

document.write(obj.name + “
”);

//将JSON字符串转为JS对象的方法二

//JSON格式的字符串

var test1 = ‘{“name”:“qlq”,“age”:25}’;

var obj2 = eval(“(” + test1 + “)”); //必须带圆括号

document.write(obj2.name + “
” + obj2.age);

结果:

runoob

qlq

25

为什么要 eval这里要添加 eval(“(” + test1 + “)”)//”呢?

原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。

加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将 括号内的表达式(expression)转化为对象,而不是作为语 句(statement)来执行。举一个例子,例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始 和结束标记,那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的:

alert(eval(“{}”); // return undefined

alert(eval(“({})”);// return object[Object]

对于这种写法,在JS中,可以到处看到。

如: (function()) {}(); 做闭包操作时等。

alert(dataObj.root.length);//输出root的子对象数量

$.each(dataObj.root,fucntion(idx,item){

if(idx==0){

return true;

}

//输出每个root子对象的名称和值

alert(“name:”+item.name+“,value:”+item.value);

})

注:对于一般的js生成json对象,只需要将$.each()方法替换为for语句即可,其他不变。

2.1.3.3.对于服务器返回的JSON字符串,如果jquery异步请求将 type(一般为这个配置属性)设为"json",或者利 用$.getJSON()方法获得服务器返回,那么就不需要eval()方法了,因为这时候得到的结果已经是json对象了,只需直接调用该对象即可,这里以$.getJSON方法为例说明数据处理方法:

$.getJSON(“http://www.phpzixue.cn/”,{param:“gaoyusi”},function(data){

//此处返回的data已经是json对象

//以下其他操作同第一种情况

$.each(data.root,function(idx,item){

if(idx==0){

return true;//同countinue,返回false同break

}

alert(“name:”+item.name+“,value:”+item.value);

});

});

这里特别需要注意的是方式1中的eval()方法是动态执行其中字符串(可能是js脚本)的,这样很容易会造成系统的安全问题。所以可以采用一些规避了eval()的第三方客户端脚本库,比如JSON in JavaScript就提供了一个不超过3k的脚本库。

2.1.3.4.补充:eval()解析的JSON的key可以不带""

一般的JSON的key必须带双引号,也就是类似于{"key":"vslue"}的形式,但是如果用eval("("+json+")")的形式解析字符串为JSON的时候,json可以写为{key:"value"}

2.2.decodeURI()与 decodeURIComponent() – 解码函数


decodeURI() 可对 encodeURI() 函数编码过的 URI 进行解码

如:

const aaa = ‘#$ ¥%23ccc/’

console.log(encodeURI(aaa)); // #$%20%EF%BF%A5%2523ccc/

console.log(decodeURI(aaa)); // #$ ¥%23ccc/

console.log(encodeURIComponent(aaa)); // %23%24%20%EF%BF%A5%2523ccc%2F

console.log(decodeURIComponent(aaa)); // #$ ¥#ccc/

我们在获取地址栏参数是通常封装成如下函数:

export function getQueryObject(url) {

url = url || window.location.href

const search = url.substring(url.lastIndexOf(‘?’) + 1)

const obj = {}

const reg = /([?&=]+)=([?&=]*)/g

search.replace(reg, (rs, $1, $2) => {

const name = decodeURIComponent($1)

let val = decodeURIComponent($2)

val = String(val)

obj[name] = val

return rs

})

return obj

}

2.3.encodeURI()与encodeURIComponent() — 编码函数


encodeURI():

语法

encodeURI(URIstring)

参数 描述

URIstring 必需。一个字符串,含有 URI 或其他要编码的文本。

返回值

URIstring 的副本,其中的某些字符将被十六进制的转义序列进行替换。

说明

该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ’ ( ) 。

该方法的目的是对 URI 进行完整的编码,因此对以下在 URI 中具有特殊含义的 ASCII 标点符号,encodeURI() 函数是不会进行转义的:;/?: @&=+$,#

encodeURIComponent() :

语法

encodeURIComponent(URIstring)

参数 描述

URIstring 必需。一个字符串,含有 URI 组件或其他要编码的文本。

返回值

URIstring 的副本,其中的某些字符将被十六进制的转义序列进行替换。

说明

该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ’ ( ) 。

其他字符(比如 :;/?😡&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。

提示和注释

提示:请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。

enCodeURI示例:

输出结果:

http://www.w3school.com.cn

http://www.w3school.com.cn/My%20first/

,/?: @&=+$#

对整个URL进行编码,而URL的特定标识符不会被转码。

encodeURIComponent() 示例:

输出结果:

http%3A%2F%2Fwww.w3school.com.cn

http%3A%2F%2Fwww.w3school.com.cn%2Fp%201%2F

%2C%2F%3F%3A%40%26%3D%2B%24%23

对URL中的参数进行编码,因为参数也是一个URL,如果不编码会影响整个URL的跳转。

2.4.escape()


语法

escape(string)

参数 描述

string 必需。要被转义或编码的字符串。

返回值

已编码的 string 的副本。其中某些字符被替换成了十六进制的转义序列。

说明

该方法不会对 ASCII 字母和数字进行编码,也不会对下面这些 ASCII 标点符号进行编码: * @ - _ + . / 。其他所有的字符都会被转义序列替换。

注意:ECMAScript v3 反对使用该方法,应用使用 decodeURI()decodeURIComponent() 替代它。

示例:

结果:

Visit%20W3School%21

%3F%21%3D%28%29%23%25%26

2.5.isFinite()


它的作用就是用来判断参数是否位于最小值和最大值之间,如果位于之间就会返回true,否则就会返回false。

在ECMAScript中能够表示的最小的数值保存在Number.MIN_VALUE中,在大多数浏览器中这个值是:5e-324;能够表示的最大的数值保存在Number.MAX_VALUE中,在大多数浏览器中,这个值是1.7976931348623157e+308,如果数值超出了范围,该值就会自动转换为一个特殊值infinity,正数的话前面会是Infinity,如果是负数的话会转换为-Infinity

可以用来判断该值是否在正常的数值范围内

2.6.isNaN()


定义和用法

isNaN() 函数用于检查其参数是否是非数字值。

isNaN的用法:检测当前值是否不是有效数字,返回true代表不是有效数字,返回false是有效数字

//=>语法:isNaN([value])

var num=12;

isNaN(num); //->检测num变量存储的值是否为非有效数字 false

isNaN(‘13’) =>false

isNaN(‘你好呀’) =>true

isNaN(true) =>false

isNaN(false) =>false

isNaN(null) =>false

isNaN(undefined) =>true

isNaN({age:9}) =>true

isNaN([12,23]) =>true

isNaN([12]) =>false

isNaN(/^$/) =>true

isNaN(function(){}) =>true

2.6.1.isNaN检测的机制:首先验证当前要检测的值是否为数字类型的,如果不是,浏览器会默认的把值转换为数字类型

[字符串转数字]

Number(‘13’) ->13

Number(‘13px’) ->NaN 如果当前字符串中出现任意一个非有效数字字符,结果则为NaN

Number(‘13.5’) ->13.5 可以识别小数

[布尔转数字]

Number(true) ->1

Number(false) ->0

[其它]

Number(null) ->0

Number(undefined) ->NaN

把引用数据类型值转换为数字:先把引用值调取toString转换为字符串,然后再把字符串调取Number转换为数字

2.6.2.当前检测的值已经是数字类型,是有效数字返回false,不是返回true(数字类型中只有NaN不是有效数字,其余都是有效数字)

parseInt / parseFloat等同于Number,也是为了把其它类型的值转换为数字类型

和Number的区别在于字符串转换分析上

Number:出现任意非有效数字字符,结果就是NaN

parseInt:把一个字符串中的整数部分解析出来,parseFloat是把一个字符串中小数(浮点数)部分解析出来

parseInt(‘13.5px’) =>13

parseFloat(‘13.5px’) =>13.5

parseInt(‘width:13.5px’) =>NaN

从字符串最左边字符开始查找有效数字字符,并且转换为数字,但是一但遇到一个非有效数字字符,查找结束

因此,使用isNaN之前,最好判断一下数据类型。

function myIsNaN(value) {

return typeof value === ‘number’ && isNaN(value);

}

判断NaN更可靠的方法是,利用NaN为唯一不等于自身的值的这个特点,进行判断。

function myIsNaN(value) {

return value !== value;

}

2.7.Number()


Number(obj)为全局函数,不依托于任何对象,用于将参数对象的值转为数值

例如:

var test1= new Boolean(true);

var test2= new Boolean(false);

var test3= new Date();

var test4= new String(“999”);

var test5= new String(“999 888”);

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

本人分享一下这次字节跳动、美团、头条等大厂的面试真题涉及到的知识点,以及我个人的学习方法、学习路线等,当然也整理了一些学习文档资料出来是附赠给大家的。知识点涉及比较全面,包括但不限于前端基础,HTML,CSS,JavaScript,Vue,ES6,HTTP,浏览器,算法等等

详细大厂面试题答案、学习笔记、学习视频等资料领取,点击资料领取直通车免费领取!

前端视频资料:
不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

[外链图片转存中…(img-qRVB2m9c-1713502178464)]

[外链图片转存中…(img-jvaDNvHv-1713502178465)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

[外链图片转存中…(img-F15TlRRv-1713502178465)]

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

[外链图片转存中…(img-dDz5EIrX-1713502178466)]

最后

本人分享一下这次字节跳动、美团、头条等大厂的面试真题涉及到的知识点,以及我个人的学习方法、学习路线等,当然也整理了一些学习文档资料出来是附赠给大家的。知识点涉及比较全面,包括但不限于前端基础,HTML,CSS,JavaScript,Vue,ES6,HTTP,浏览器,算法等等

详细大厂面试题答案、学习笔记、学习视频等资料领取,点击资料领取直通车免费领取!

[外链图片转存中…(img-MhKz8tjq-1713502178466)]

前端视频资料:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值