当前位置: 首页 > wzjs >正文

网站常见问题是什么seo网站优化收藏

网站常见问题是什么,seo网站优化收藏,建设项目一次公示网站,做企业网站的轻量级cmsJavaScript 中 apply、call 和 bind 方法的手写实现 call 的实现 与 apply 类似,但参数以逗号分隔传递 // 给所有的函数添加一个mycall的方法 Function.prototype.mycall function (context, ...args) {// 在这里可以去执行调用的那个函数(foo)// 问题: 得可以获…
JavaScript 中 apply、call 和 bind 方法的手写实现
call 的实现

与 apply 类似,但参数以逗号分隔传递

// 给所有的函数添加一个mycall的方法
Function.prototype.mycall = function (context, ...args) {// 在这里可以去执行调用的那个函数(foo)// 问题: 得可以获取到是哪一个函数执行了mycall// 1.获取需要被执行的函数if (typeof this !== "function") {throw new TypeError("Function.prototype.mycall called on non-function");}// 2.对context转成对象类型(防止它传入的是非对象类型)context =context !== null && context !== undefined ? Object(context) : window;// 3.创建唯一属性键const fnKey = Symbol("fn");// 4. 将当前函数绑定到 contextcontext[fnKey] = this;// 5.调用需要被执行的函数var result = context[fnKey](...args);// 6. 删除临时属性delete context[fnKey];// 7.将最终的结果返回出去return result;
};
  • 测试代码
function foo(a, b, c) {console.log(this, a, b, c);
}
foo.mycall({ name: "zs" }, 1, 2, 3);
foo.mycall(null, 1, 2, 3);
foo.mycall(undefined, 1, 2, 3);
foo.mycall(123, 1, 2, 3);

在这里插入图片描述

apply 的实现

立即执行函数,将 this 绑定到指定对象,参数以数组形式传递

// 给所有的函数添加一个myapply的方法
Function.prototype.myapply = function(context, argArray) {// 在这里可以去执行调用的那个函数(foo)if (typeof this !== 'function') {throw new TypeError('Function.prototype.mycall called on non-function');}// 2.对context转成对象类型(防止它传入的是非对象类型)context = (context !== null && context !== undefined) ? Object(context): windowconst fnKey  = Symbol('fn')//  将当前函数绑定到 contextcontext[fnKey] = this// 处理参数,当不传入参数,argArray为undefined,...undefined会报错,所以需要处理一下argArray = argArray || []// 3.调用需要被执行的函数var result = context[fnKey](...argArray)delete context[fnKey]// 4.将最终的结果返回出去return result
}
  • 测试代码
function foo(a, b, c) {console.log(this, a, b, c); 
}
foo.myapply({ name: "zs" }, [1, 2, 3]);
bind 的实现

返回新函数,永久绑定 this 和预设参数

Function.prototype.mybind = function(context, ...argArray) {// 1.获取到真实需要调用的函数if (typeof this !== "function") throw new TypeError("必须是函数");const fn = this// 2.绑定thiscontext = (context !== null && context !== undefined) ? Object(context): windowconst fnKey  = Symbol('fn')function newFn(...args) {// 3.将函数放到context中进行调用context[fnKey] = fn// 特殊: 对两个传入的参数进行合并var finalArgs = [...argArray, ...args]var result = context[fnKey](...finalArgs)delete context[fnKey]// 4.返回结果return result}return newFn
}
  • 测试代码
function foo() {console.log("foo被执行", this)return 20
}function sum(num1, num2, num3, num4) {console.log(num1, num2, num3, num4)console.log(this)
}

在这里插入图片描述

http://www.dtcms.com/wzjs/528948.html

相关文章:

  • 福建祥盛建设有限公司网站seo怎么学
  • 郑州建站多少钱今日刚刚发生新闻事件
  • 餐饮网站开发性能需求海外营销推广服务
  • 网站排名seo知识搜索引擎
  • 网络宣传推广方法sem优化策略
  • 优秀企业站网站外贸营销网站建站
  • 网站建设投标书怎么制作自己个人怎样做电商
  • 合作网站制作seo千享科技
  • wordpress备案号格式成都优化网站哪家公司好
  • wordpress 表单邮件seo优化排名营销
  • 品牌网站建设企业广州外贸推广
  • 网站备份与恢复网络营销推广处点
  • 网站开发合同下载百度站长平台官网
  • 站长之家网站建设制作建站的公司
  • 网站建设需要什么流程深圳网站建设找哪家公司好
  • 网站怎么做最吸引人推广商
  • 百度显示网站正在建设中百度账号查询
  • 做网站背景图的科技图片2023年6月疫情情况
  • 企业网站的建设包括哪些营销型企业网站诊断
  • 对公司网站建设的建议网站推广公司推荐
  • 找别人做公司网站第一步做什么广告投放平台系统
  • 湖南常德最新疫情最新消息关键词的分类和优化
  • 潜江 网站建设网站排行
  • cms公司中国兰州seo优化
  • 有做销售产品的网站有哪些内容网络营销案例分析题
  • 网站你啦怎样做旺仔饼干女教师遭网课入侵视频
  • 网站开发参考书目企业网站seo排名优化
  • 环保公司网站建设宣传图片公司调查公司
  • 做经营性的网站需要注册什么百度外推排名代做
  • 湖南营销型网站建设 干净磐石网络青岛网站seo诊断