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

做欧洲电商看哪个网站吗/seo怎么做优化

做欧洲电商看哪个网站吗,seo怎么做优化,wordpress 登录 手机版,广州做外贸网站多少钱序昨天写了篇通过jQuery源码学习javascript(一),里面有一个定义对象C的方法,我早期也没有太注意这个方面的技术细节。后来我查了一下资料,发现里面有很多巧的地方。今天与大家分享。巧妙1:函数在javascript…
昨天写了篇通过jQuery源码学习javascript(一),里面有一个定义对象C的方法,我早期也没有太注意这个方面的技术细节。后来我查了一下资料,发现里面有很多巧的地方。今天与大家分享。
巧妙1:函数
在javascript代码中函数是个不可多得的人才。
♥ 它可以归置代码段,封装相对独立的功能。
♥ 它也可以实现类,注入OOP思想。
jQuery就是一个函数,你也可以把它当成类(呵呵,本身就是类)。
(function(){var jQuery = function() {// 函数体
    }   window.jQuery = window.$ = jQuery;
})();
console.log(jQuery);

                                     输出结果

     

上面的空函数就是所谓的构造函数,构造函数在面向对象语言中是类的一个基本方法。

巧妙2:扩展原型
何为原型对象?我给出一篇博文大家可以去了解一下http://www.cnblogs.com/gnface/archive/2012/08/22/2651534.html。
javascript为所有函数绑定一个prototype属性,由这个属性指向一个原型对象。我们在原型对象中定义类的继承属性和方法等。
原型对象是javascript实现继承的基本机制。
(function(){var jQuery = function() {// 函数体
    }jQuery.fn = jQuery.prototype = {// 扩展原型对象jquery: "1.8.3",test: function() {console.log('test');}}window.jQuery = window.$ = jQuery;
})();(new jQuery()).test();

 

巧妙3:使用工厂方法来创建一个实例

  上面的方法必须使用下面的方法才能进行调用,这样就会产生很多对象,从而浪费内存消耗。

(new jQuery()).test();

  jQuery源码使用了很柔和的方法,也是大家比较熟悉的工厂方法,进行调用。

(function(){var jQuery = function() {// 函数体return jQuery.fn.init();}jQuery.fn = jQuery.prototype = {// 扩展原型对象jquery: "1.8.3",init: function() {return this;},  test: function() {console.log('test');}   }   window.jQuery = window.$ = jQuery;
})();
jQuery().test();

假想1:让jQuery函数体直接返回该对象——我用this

(function(){var jQuery = function() {return this;}   jQuery.fn = jQuery.prototype = {// 扩展原型对象jquery: "1.8.3",test: function() {console.log('test');}   }   window.jQuery = window.$ = jQuery;
})();
console.log(jQuery());

                                     输出结果

发现这里的this指向Window对象。  

 

假想2:让jQuery函数体直接返回类的实例。

(function(){var jQuery = function() {return new jQuery();}   jQuery.fn = jQuery.prototype = {// 扩展原型对象jquery: "1.8.3",test: function() {console.log('test');}   }   window.jQuery = window.$ = jQuery;
})();
console.log(jQuery());

                                     输出结果

发现上面是一个递归死循环,出现内存外溢。



巧妙4:分隔作用域

思考1:init()方法返回的this作用域是什么?

(function(){var jQuery = function() {// 函数体return jQuery.fn.init();}jQuery.fn = jQuery.prototype = {// 扩展原型对象jquery: "1.8.3",init: function() {this.init_jquery = '2.0';return this;}}   window.jQuery = window.$ = jQuery;
})();   
console.log(jQuery().jquery);
console.log(jQuery().init_jquery);

                                     输出结果

  

init()方法中的this作用域:this关键字引用了init()函数作用域所在的对象,同时也能够访问上一级对象jQuery.fn对象的作用。——这种思路会破坏作用域的独立性,对于jQuery框架来说,很可能造成消极影响。

思考2:怎么把init()中的this从jQuery.fn对象中分隔出来?——实例化init初始化类型。

(function(){var jQuery = function() {// 函数体return new jQuery.fn.init();}jQuery.fn = jQuery.prototype = {// 扩展原型对象jquery: "1.8.3",init: function() {this.init_jquery = '2.0';return this;}}   window.jQuery = window.$ = jQuery;
})();   
console.log(jQuery().jquery);
console.log(jQuery().init_jquery);

                                     输出结果

    

通过实例化init()初始化类型,限定了init()方法里的this,只在init()函数内活动,不让它超出范围。

巧妙5:原型传递
思考1:在巧妙4中,我们把init()中的this从jquery.fn对象中分隔出来。那我们如何能做到保证“巧妙4”的基础上,还能访问jQuery原型对象呢?——原型传递。
让jQuery的原型对象覆盖init()构造器的原型对象。
jQuery.fn.init.prototype = jQuery.fn;

全部代码:

(function(){var jQuery = function() {// 函数体return new jQuery.fn.init();}jQuery.fn = jQuery.prototype = {// 扩展原型对象jquery: "1.8.3",init: function() {this.init_jquery = '2.0';return this;}}   jQuery.fn.init.prototype = jQuery.fn;window.jQuery = window.$ = jQuery;
})();
console.log(jQuery().jquery);
console.log(jQuery().init_jquery);

                                     输出结果

妙棋

  把init()对象的prototype指针指向jQuery.fn。——这样init()里的this继承了jQuery.fn原型对象定义的方法和属性。

总结
感谢博友的留言,尤其是puni,给我介绍了一本不错的书。如果大家能补充一下,那就再好不过了。
推荐
http://www.lbrq.cn/news/965413.html

相关文章:

  • 台州市建设项目规划网站/网页制作公司哪家好
  • 做测试日本网站/最好的免费推广平台
  • 免费模板网站制作/推广是什么意思
  • 完美日记网络营销策略分析/seo排名如何
  • 网站建设潮州/网站搜索引擎优化情况怎么写
  • 怎么查询网站有没有做网站地图/百度云搜索引擎 百度网盘
  • 北京网站建设公司兴田德润专业/刷关键词排名软件有用吗
  • 企业网站做多大尺寸/外贸谷歌优化
  • 公司网站建设沈阳/seo引擎
  • 延吉网站建设公司ybdiran/沈阳网站建设
  • mac运行wordpress/网站优化排名提升
  • 公司开个网站多少钱/苏州百度搜索排名优化
  • 网站做管理员消息推送/线上营销推广的公司
  • 公司网站建设宣传报道稿件/市场营销是做什么的
  • 宝塔面板做网站不能打开PHP显示404/建设网站制作
  • 上海网站搜索排名优化哪家好/北京百度推广投诉电话
  • 手机网站模板单页/现在学seo课程多少钱
  • 网页设计教程课本课后题答案/购买seo关键词排名优化官网
  • 云阳有没有做网站的/seo排名优化怎样
  • 网站后台管理系统设计/seo怎么做最佳
  • 购物网站怎么做/百度seo在哪里
  • 网站提供什么服务/网络营销的策划方案
  • 如何对网站做渗透/做网站推广
  • 桂林网站制作多少钱/百度广告怎么推广
  • 手机怎么自创网站/百度一级代理商
  • 电商网站怎么做聚合/北京seo的排名优化
  • 神奇网站/朋友圈推广一天30元
  • 大连筑成建设集团有限公司网站/郑州seo网络营销
  • 安新网站建设/怎样推广产品
  • 上海网站制作网站建设/杭州seo招聘
  • 【Lua】题目小练2
  • Java—异常Exception
  • 大语言模型(LLM)训练的教师强制(Teacher Forcing)方法
  • 【C#地图显示教程:实现鼠标绘制图形操作】
  • 【网络安全】大型语言模型(LLMs)及其应用的红队演练指南
  • 记录自己在将python文件变成可访问库文件是碰到的问题