今天发现这么一个函数eval eval能够将传入的字符串当做js代码执行 例如处理json(请不要这样使用,正确的做法应该是使用JSON.parse(data)): let data = '{"nane...":"ruben","age":11}' eval("("+data+")") console.log(eval('2 + 2')); // expected output: 4 console.log...(eval(new String('2 + 2'))); // expected output: 2 + 2 console.log(eval('2 + 2') === eval('4')); //...expected output: true console.log(eval('2 + 2') === eval(new String('2 + 2'))); // expected output:...';所以提示禁止使用eval Uncaught EvalError: Refused to evaluate a string as JavaScript because 'unsafe-eval'
前言 call 和 apply 都是为了改变某个函数运行时的 context 即上下文而存在的,换句话说,就是为了改变函数体内部 this 的指向。 ...call 和 apply二者的作用完全一样,只是接受参数的方式不太一样。...方法定义 apply Function.apply(obj,args)方法能接收两个参数: obj:这个对象将代替Function类里this对象 args:这个是数组或类数组,apply...call call方法与apply方法的第一个参数是一样的,只不过第二个参数是一个参数列表 在非严格模式下当我们第一个参数传递为null或undefined时,函数体内的this会指向默认的宿主对象...,在浏览器中则是window var test = function(){ console.log(this===window); } test.apply(null);//true test.call
前言 apply() 的作用有两个: 1. 改变 this 指向 2....将数组入参变为一般入参 刚开始看到 apply() 时,对它的用法非常模糊,而且不易理解,通过查找相关文章,才慢慢的明白它的妙用 2....(person1) console.log(res); // Bill Gates 如何理解 apply() 这段代码 ?...person.fullName() 调用 this.firstName 和 this.lastName 这两个属性,this 指向 person,但它没有这两个属性 使用 apply() 方法可以改变...) 的第二个参数将数组入参变为一般入参 注意,这里的第一个参数值为 null,也就是没有改变 this 的指向 Math.max.apply(null, [, , ])
该方法的语法和作用与 apply() 方法类似,只有一个区别,就是 call() 方法接受的是一个参数列表,而 apply() 方法接受的是一个包含多个参数的数组。...for (var i = 1, len = arguments.length; i < len; i++) { args.push('arguments[' + i + ']'); } eval..., len = arguments.length; i < len; i++) { args.push('arguments[' + i + ']'); } var result = eval...apply 可以使用数组字面量(array literal),如 fun.apply(this, ['eat', 'bananas']),或数组对象, 如 fun.apply(this, new Array...len = args.length; i < len; i++) { args_arr.push('arguments[' + i + ']'); } result = eval
Js apply方法详解 我在一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这里我做如下笔记...主要我是要解决一下几个问题: apply和call的区别在哪里 什么情况下用apply,什么情况下用call apply的其他巧妙用法(一般在什么情况下可以使用apply) 我首先从网上查到关于apply...apply:方法能劫持另外一个对象的方法,继承另外一个对象的属性....) call:和apply的意思一样,只不过是参数列表不一样....apply的方式巧妙地解决这个问题!
JS混淆加密:变量赋值Eval加密 先来看实现后的效果: 能看出这是一句赋值语句吗? 它混淆前的源码是: 即:a=2;这一句。 更准确的说是: 此图的效果是a=2;的第一重保护。...再把赋值语句转为eval函数调用表达式,用于执行语句,使赋值操作正常完成。 执行效果如下: 对应源码可知,赋值成功。
JS的eval函数解密反混淆 作者:matrix 被围观: 10,699 次 发布时间:2014-05-14 分类:零零星星 | 15 条评论 » 这是一个创建于 3032 天前的主题,其中的信息可能已经有所发展或是发生改变...打开有些js文件看到的eval(function(p,a,c,k,e,d)开头,只有结尾部分有很多竖线|间隔的字符,这是eval混淆了的。想要查看原本的代码就需要反混淆。
前天去面试,有个gg问了一些js知识,其中有一道call与apply用法的题目,尽管在365天前用过call方法,但当时还是没能答上来,今天深入总结一下 call和apply,它们的作用都是将函数绑定到另外一个对象上去运行...两者的格式和参数定义: call( thisArg [,arg1,arg2,… ] ); // 参数列表,arg1,arg2,... apply(thisArg [,argArray]...doctype html> call-apply <input type="text" id...因此this.value为this.a,即func 6、函数func2调用call方法,第二个参数属于函数对象func2的参数,因此alert(x)为第二个参数func2 二、call 继承用法与改进 js...doctype html> call - apply for inherit <script
js的call apply bind 方法都很常见,目的都是为了改变某个方法的执行环境(context) call call([thisObj[,arg1[, arg2[, [,.argN]]]]]...window : context; var temp = [], evalStr = ''; // 最后要形成 一个eval字符串函数调用形式,以供动态执行..._apply(' + temp.join(',') + ')'; // console.log(evalStr); try{ eval(evalStr); }catch..._apply(' + temp.join(',') + ')'; console.log(evalStr); try{ eval(evalStr); }catch..._apply(' + temp.join(',') + ')'; console.log(evalStr); try{ eval(evalStr); }catch
贪玩蓝月真好玩,但学习还是要继续的 我们平时调用一个js函数是这样的 var ruben = { say: function (word) { if (this.name ==...(Achao, "村头恶霸华农、刑部尚书手工耿、木瓜大盗莫叔、非洲人犯朱一旦") console.log(whatAchaoSaid); 输出结果 这就是call函数的使用方式和场景了 那么还有一个apply...和call不同,它调用方法给的参数需要是一个数组 var Hegel = { name: "黑格尔" } var whatHegelSaid = ruben.say.apply(Hegel, [
一、call和apply简介 call() 和 apply() 是预定义的函数方法。 两个方法可用于调用函数,两个方法的第一个参数必须是对象本身。 两个方法都使用了对象本身作为第一个参数。...两者的区别在于第二个参数: apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。...二、call和apply的相同点和不同点 1. 区别 call传递的参数是序列1,2,3,4 apply传递的参数是集合型[1,2,3,4] 2....相同点 call和apply是替换前面函数内部的this指针以及传递参数。 功能:可以自动执行前面的函数 都有两个参数:a. 替换的对象 b....function method(a,b,c){ console.log(this,a,b,c);//{name: "张三", age: 20} 1 2 3 } method.apply
并且会返回一个修改之后的新函数给我们 注意点: bind方法除了可以修改this以外, 还可以传递参数, 只不过参数必须写在this对象的后面 */ //call apply...修改函数或者方法中的this为指定的对象, 并且会立即调用修改之后的函数 注意点: call方法除了可以修改this以外, 还可以传递参数, */ /*apply...:修改函数或者方法中的this为指定的对象, 并且会立即调用修改之后的函数 注意点: apply方法除了可以修改this以外, 还可以传递参数, 只不过参数必须通过数组的方式传递...window.test(); let fn=test.bind(obj,10,20); fn(); test.call(obj,10,20); test.apply...p.say(); let fn=p.say.bind(obj); fn(); p.say.call(obj); p.say.apply
call和apply 1.....); obj.apply(thisObj, [arg1, arg2, ...]); call和apply作用相同,都是把obj(即this)绑定到thisObj,这时候thisObj具备了obj的属性和方法...唯一区别是apply接受的是数组参数,call接受的是连续参数。...(sub, [5, 3]); //8 sub具有了add的属性和方法 sub(5, 3); //2 sub.call(add, 5, 3); //2 add具有了sub的属性和方法 sub.apply...与call和apply不同的是,bind绑定后不会立即执行。
Window return num1 + num2; } const obj = {}; getSum.call(obj, 2, 3); // this指向: obj return: 5 2. apply...() 语法: fun.apply(thisArg,[arg1,arg2,…]) fun: 表示一个函数 thisArg: this要指向的对象,如果是null 和 undefined,则指向window...特性: fun.apply(thisArg,[arg1,arg2,…]) 会立即调用fun函数; apply方法将一个函数的对象上下文从初始的上下文改变为由 thisArg 指定的新对象,如果没有提供...() apply 常用于与数组有关的操作,因为传递的参数是数组。...获取数组中的最大值与最小值: const arr = [1, 4, 7, -1]; Math.max.apply(Math, arr); // 7 Math.min.apply(Math, arr);
调用函数时, call和apply传递参数的方式不同 以名为showHide的函数为例: function showHide(name1, name2){ if(this.parentNode.parentNode.querySelector..."span").innerHTML = "(点击折叠)"+name1+","+name2; } } call可以按照顺序传递showHide.call(this, '桐人', '亚丝娜') apply...则是将参数放到一个数组, 统一传递showHide.apply(this, ['上条', '御坂']) 用call和apply实现相同的折叠的Demo ?... 小结: 使用call和apply
在js中this有4种指向,分别为: 作为对象的方法调用 作为普通函数调用 构造器调用 Function.prototype.call或Function.prototype.apply调用 1、当作为对象的方法调用时...方法赋值给新的变量func2时,func2就是一个全局作用域中的普通函数,而非obj对象中的方法,已经与getName方法是两个完全独立的方法,拥有完全不同的作用域上下文*/ 3、在构造器中调用this 先要理解js...apply接收两个参数,第一个参数指定了调用apply的函数体内this对象的指向,第二个参数是一个带下标的集合,该集合可以是数组,也可以是类数组,apply方法把这个集合中的所有元素作为参数依次传递给调用...关于apply或call,两者的作用完全一致,都是更改调用apply或call的函数体内的this对象指向。...延伸应用: 理解了this、call、apply后,在实际js开发中,可以很方便的实现对象的继承 继承demo1: 1var Parent = function(){ 2 this.name
前言 回想起之前的一些面试,几乎每次都会问到一个js中关于call、apply、bind的问题,比如… 怎么利用call、apply来求一个数组中最大或者最小值 如何利用call、apply来做继承 apply...所以其实他们干的事从本质上讲都是一样的动态的改变this上下文,但是多少还是有一些差别的.. call、apply与bind的差别 call和apply改变了函数的this上下文后便执行该函数,而bind...;fn.apply(obj, [arg1, arg2, arg3...]); 应用 知道了怎么使用和他们之间的区别,接下来我们来了解一下通过call、apply、bind的常见应用场景。...,-8,687); 将伪数组转化为数组 js中的伪数组(例如通过document.getElementsByTagName获取的元素)具有length属性,并且可以通过0、1、2…下标来访问其中的元素...Array.prototype.slice.call(arrayLike); 上面arr便是一个包含arrayLike元素的真正的数组啦( 注意数据结构必须是以数字为下标而且一定要有length属性 ) 数组追加 在js
~ 把call、apply、bind一条龙都整一遍!...arg1 + arg2)}const _this = { name: 'YIYING' }// 接受的是一个参数列表;方法立即执行fun.ownCall(_this, 1, 2)// 输出:YIYING3apply...定义与使用Function.prototype.apply(): developer.mozilla.org/zh-CN/docs/…// Function.prototype.apply()样例function...console.log(this.name) console.log(arg1 + arg2)}const _this = { name: 'YIYING' }// 参数为数组;方法立即执行fun.apply...(_this, [1, 2])// 输出:YIYING3手写实现/** * 自定义Apply实现 * @param context 上下文this对象 * @param args 参数数组
JS中的call()和apply()方法 1、方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[, [,.argN]]]]]) 定义:调用一个对象的一个方法,...apply方法: 语法:apply([thisObj[,argArray]]) 定义:应用某一对象的一个方法,用另一个对象替换当前对象。...add.call(sub,3,1); 这个例子中的意思就是用 add 来替换 sub,add.call(sub,3,1) == add(3,1) ,所以运行结果为:alert(4); // 注意:js...18 { 19 Class10.call(this); 20 Class11.call(this); 21 } 很简单,使用两个 call 就实现多重继承了 当然,js...说了call ,当然还有 apply,这两个方法基本上是一个意思,区别在于 call 的第二个参数可以是任意类型,而apply的第二个参数必须是数组,也可以是arguments 还有 callee,caller
~ 把call、apply、bind一条龙都整一遍!...const _this = { name: 'YIYING' }// 接受的是一个参数列表;方法立即执行fun.ownCall(_this, 1, 2)// 输出:YIYING3参考 前端手写面试题详细解答apply...定义与使用Function.prototype.apply(): developer.mozilla.org/zh-CN/docs/…// Function.prototype.apply()样例function...console.log(this.name) console.log(arg1 + arg2)}const _this = { name: 'YIYING' }// 参数为数组;方法立即执行fun.apply...(_this, [1, 2])// 输出:YIYING3手写实现/** * 自定义Apply实现 * @param context 上下文this对象 * @param args 参数数组
领取专属 10元无门槛券
手把手带您无忧上云