JavaScript对象的几种创建方式
1.字面量创建
var obj = {
name:"web",
eat:function(){}
}
缺点:代码冗余,适合单个对象创建
2.实例创建
var obj = new Object();
obj.name = "web";
obj.eat = function(){}
缺点:代码冗余,适合单个对象创建
3.工厂模式创建
function createObj(name){
var obj = new Object();
obj.name = name;
obj.eat = function(){}
return obj
}
createObj(“web”);
缺点:识别不明确
4.构造函数创建
function Student(name){
//new Object
this.name = name;
this.eat = function(){}
}
new Student(name)
缺点:浪费内存
5.原型创建
原型对象:prototype ,构造函数中,共享的一块区域
原型属性:__proto__,实例对象中,指向原型对象
function Student(){}
Student.prototype.name = "web";
Student.prototype.eat = function(){}
new Student();
缺点:不能传参
6.混合创建,构造函数(可变的)+原型(共享,不变的)
function Student(name){
this.name = name;
}
Student.prototype.eat = function(){
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义