用原型封装一个操作DOM的例子
<script> // 一句话 在构造函数里面写属性 在原型里面写方法 function Elem(d){ this.even=document.getElementById(d); } Elem.prototype.html=function(val){ var e = this.even; if(val){ e.innerHTML=val; return this; // 链式操作 返回整个这个Elem.prototype.html整体 ,不写这个return 就不能进行链式操作 }else{ return e.innerHTML; } } Elem.prototype.on=function(type,fn){ var e = this.even; e.addEventListener(type,fn); return this;//同理 也是为了能够继续链式操作 } var box = new Elem('page-info'); // box.html('123') // box.on('click',function(){ // alert('test') // }) // 上面注释部分的链式操作 // box.html('123').on('click',function(){ alert('test')}) box.html('123').on('click',function(){ alert('test')}).html('从123变成456') </script>
字面量形式的原型
var vehicle = function(){ this.door=4; } vehicle.prototype ={ getName: function(){ return 'vehicle' }, getInfo: function(){ return [ this.getName(),'has',this.door,'doors' ].join(',') } } var vehicle = new vehicle(); console.log(vehicle.getInfo()) // vehicle,has,4,doors
链式赋值说明
let a = b = c = 12 链式赋值会创建隐形的全局变量 不建议这样赋值 建议如下 let a; let b; let c;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?