JS-构造函数2】的更多相关文章

$(function(){ var rec = new Rectangle(5, 10); //alert(rec.width + "*" + rec.height + "=" + rec.area()); //alert(rec.hasOwnProperty("width")); //alert("area" in rec); //alert(rec.toString()); var message = "hell…
//构造函数 //使自己的对象多次复制,同时实例根据设置的访问等级可以访问其内部的属性和方法 //当对象被实例化后,构造函数会立即执行它所包含的任何代码 function myObject(msg) { //特权属性(公有属性) this.myMsg = msg; //只在被实例化后的实例中可调用 this.address = 'Chengdu'; //私有属性:无法通过对象直接访问 var name = 'Tirion'; var that = this; //私有方法 function sa…
Class 在语法上更加贴合面向对象的写法 Class 实现继承更加易读.易理解 更易于写 java 等后端语言的使用 本质还是语法糖,使用 prototype Class语法 typeof MathHandle // 'function' MathHandle.prototype.construcroe === MathHandle  // 构造函数的显示原型有个construvtor等于它的构造函数本身 m.__proto__ === MathHandle.prototype // true…
js 构造函数 & 静态方法 & 原型 & 实例方法 ES5 "use strict"; /** * * @author xgqfrms * @license MIT * @copyright xgqfrms * @created 2020-10-10 * @modified * * @description 构造函数 静态方法 & 构造函数的原型 实例方法 * @description 构造函数上添加只有构造函数可以访问的静态方法 * @descrip…
很快就要从新浪离职了,最近心情比较轻松,抽点空整理一下构造函数和原型的机理. 我们都知道,在经典设计模式中我们最常用的就是工厂模式.构造函数模式.原型模式这几种,听起来‘模式’好像很高大上的样子,实际上我们在日常写js代码中会经常用到. 简单的说,工厂模式就是我们平常写的一个个函数,当要完成某项功能时,就一遍一遍调用这个函数.如: function add(a,b){ return a+b; } 这是一个很简单的代码,完成的是一个很简单的两数相加的功能,当我们需要两数相加的计算时,调用这个函数就…
本文主要介绍和小结js的构造函数,关联数组的实现方式和使用,及不可变对象和它的实现方式及他们使用过程中要注意的点 <script> function p(){ var len=arguments.length; for(var i=0;i<len;i++){ document.write(arguments[i]+"<br/>"); } } function Myclass(x,y){ this.x=x; this.y=y; this.show=funct…
1.创建对象有以下几种方式: ①.var obj = {}; ②.var obj = new Object(); ③.自定义构造函数,然后使用构造函数创建对象 [构造函数和普通函数的区别:函数名遵循大驼峰式命名规则,通常我们使用构造函数创建对象] 2.构造函数内部原理 ①.在函数体内部隐式的加上 var this = {}[当然这个var this={}实际上是在AO对象中创建的!] ②.执行this.xxx = xxx; ③.隐式的返回this 代码如下所示: <script type="…
1.面向对象:js原型 java有class和instance,js仅仅有构造函数(function Cat(name,age){this.name=name;this.age=age}),为了实现数据共享和抽象出通用的属性,加了一个原型prototype eg: function Cat(name,age){ this.name = name;//这里的this相当于java里面的instance this.age = age; this.work = function(){ alert("I…
1.对象创建的3中方法 1.1.对象字面量 var obj = { name: "mingzi", work: function () { console.log("working...") }, _age: 18, //下划线开头表示该属性不建议在外部被直接访问,但是任然可以被访问,除非使用类或函数定义 //age: 18,使用下划线定义属性后,对象上会默认生成这样一个没有下划线的属性引用,指向同一个值,用来被外部访问 get age(){ console.log…
一.首先说一下什么是构造函数: 构造函数:用来在创建对象时初始化对象.特点:构造函数名一般为大写字母开头:与new运算符一起使用来实例化对象. 举例: function Person(){} //Person构造函数var p=new Person(); //Person构造函数创建对象,也可叫做实例化 二.什么是原型?原型:构造函数在创建的过程中,系统自动创建出来与构造函数相关联的一个空的对象.可以由构造函数.prototype来访问到. 举例:在实例化对象p的过程中,系统就自动创建出了构造函…
本文链接:https://blog.csdn.net/qq_36209248/article/details/89190978 默认情况下,没有return的函数的返回值为undefined(即没有定义返回值),如果定义了return,则返回指定对象.但是构造函数比较t特殊,new构造函数在没有return的情况下默认返回新创建的对象.在有return的情况下,需要分为两个情况考虑: 如果返回值为基本数据类型(string,number,boolean,undefined,null),那么返回值…
function foo(name) { this.name = name; return name } console.log(new foo('光何')) function bar(name) { this.name = name; return ['光','何'] } console.log(new bar('光何')) 结果为: 'ooo {name: "光何"}' 'Array(4) ["光", "何"]' 创建JS对象两种方式 在Ja…
把方法写在构造函数内的情况我们简称为函数内方法,把方法写在prototype属性上的情况我们简称为prototype上的方法 函数内的方法: 使用函数内的方法我们可以访问到函数内部的私有变量,如果我们通过构造函数new出来的对象需要我们操作构造函数内部的私有变量的话, 我们这个时候就要考虑使用函数内的方法. prototype上的方法: 当我们需要通过一个函数创建大量的对象,并且这些对象还都有许多的方法的时候;这时我们就要考虑在函数的prototype上添加这些方法. 这种情况下我们代码的内存占…
JavaScript对象的创建方式 在JavaScript中,创建对象的方式包括两种:对象字面量和使用new表达式.对象字面量是一种灵活方便的书写方式,例如: ? 1 2 3 4 5 6 var o1 = {     p:"I'm in Object literal",     alertP:function(){         alert(this.p);     } } 这样,就用对象字面量创建了一个对象o1,它具有一个成员变量p以及一个成员方法alertP.这种写法不需要定义构…
//构造函数  //使自己的对象多次复制,同时实例根据设置的访问等级可以访问其内部的属性和方法  //当对象被实例化后,构造函数会立即执行它所包含的任何代码  function myObject(msg){      //特权属性(公有属性)      this.myMsg = msg; //只在被实例化后的实例中可调用      this.address = '上海';            //私有属性      var name = '豪情';      var age = 29;    …
//构造函数 //使自己的对象多次复制,同时实例根据设置的访问等级可以访问其内部的属性和方法 //当对象被实例化后,构造函数会立即执行它所包含的任何代码 function myObject(msg) { //特权属性(公有属性) this.myMsg = msg; //只在被实例化后的实例中可调用 this.address = 'Chengdu'; //私有属性:无法通过对象直接访问 var name = 'Tirion'; var that = this; //私有方法 function sa…
1.直接传参并用this关键字初始化属性 function Person(name,age,learn){ this.name = name; this.age = age; this.learn = learn || false; } Person.prototype.isWork=false; Person.prototype.work=function(){ this.isWork=true; }; Person.prototype.unwork = function(){ this.is…
使用函数做自动化 function createObj(nick, age){ var obj = { nick: nick, age: age, printName: function(){ console.log(this.nick); } }; return obj; } var obj3 = createObj('Byron', 30); obj3.printName(); 我们通过创建一个函数来实现自动创建对象的过程 有型一些 要想让我们构造出的函数有型一些,我们需要了解一些额外知识…
构造函数是可以创建特定类型对象的函数,可以接受参数定义函数成员.如果之前做过java比较好理解,举个例子: function exampleFunction(arg1, arg2, arg3){ this.arg1 = arg1; this.arg1 = arg1; this.arg1 = arg1; this.output = function(){ console.log('walk' + arg3); } } 用法是用new关键字创建实例: var instance1 = new exam…
构造函数方法有对象方法.类方法.原型方法,这些方法在什么时候可以调用,什么时候不能调用,为什么? function Func(name){ this.name=name; this.ff=function(){ //对象方法 console.log(this.name); }; } Func.ff2=function(name){//类方法 console.log(name); } Func.prototype.ff3=function(){//原型方法 console.log(this.nam…
This 解析器再调用函数每次都会向函数内部传递一个隐含的参数this,this指向的是一个对象(函数执行的上下文对象) 1.以函数形式调用时,this永远是window. 2.以方法形式调用时,this就是调用方法的那个对象 3.当以构造函数的形式调用时,this就是新创建的那个对象 使用工厂的方法创建对象 通过该方法可以大批量的创建对象,这样创建的对象使用的构造函数都是Object,无法区分多种不同类型的对象. function create(name,age,geder){ var obj…
本文的目的是让大家理解什么情况下把函数的方法写在JavaScript的构造函数上,什么时候把方法写在函数的 prototype 属性上;以及这样做的好处. 为了阅读方便,我们约定一下:把方法写在构造函数内的情况我们简称为 函数内方法 ,把方法写在 prototype 属性上的情况我们简称为 prototype上的方法 首先我们先了解一下这篇文章的重点: 函数内的方法:使用函数内的方法我们可以 访问到函数内部的私有变量 ,如果我们通过构造函数 new 出来的对象需要我们操作构造函数内部的私有变量的…
翻出来之前的一些效果,觉得这个时钟还挺好玩的就写出来共大家分享: HTML代码如下: <div id="box"> </div> 当前盒子用于插入钟表内容: js代码如下: <script> function clock(size,panBorderWidth){ this.size = size || 400; this.pan; this.panBorderWidth = panBorderWidth || 5; this.sp; this.mp…
目录 构造函数与原型介绍 涉及三种引用的操作 有关原型及原型链的一些相关方法总结 @ 构造函数与原型介绍 1.函数与函数的原型对象(prototype object): 在JavaScript中,创建一个函数A, 浏览器就会在内存中创建一个对象B,而且该函数默认会有一属性 prototype 指向这个对象(即:prototype属性的值) 这个对象B就是函数A的原型对象,简称函数的原型.原型对象B也默认会有一个属性 constructor 指向了这个函数A (即:constructor属性的值是…
* 构造函数: * 1.构造函数的函数名最好首字母大写(否则 WebStorm 编辑器会提示报错) * 2.自己的对象多次被复制 * 3.构造函数里可以创建公有属性.公有方法.私有属性和私有方法 * 3.构造函数内部的方法可以访问构造函数内部的属性 * 4.当对象被实例化后,构造函数会立即执行它所包含的所有代码 * 5.私有方法和私有属性都不对外公开,即使创建构造函数的实例化对象,依旧不能访问,只能在构造函数内部进行访问 /** * 构造函数: * 1.构造函数的函数名最好首字母大写(否则 We…
任何函数,只要通过 new 操作符来调用,那它就可以作为构造函数 如:任何函数,只要通过 new 操作符来调用,那它就可以作为构造函数 : fuction Preson(){...} var preson = new Preson("飞哥","19","男"); //this 指向 preson document.write(preson.FirstName); //调用构造函数 无论是构造函数还是非构造函数,两者并没有实质性的区别:构造函数可以…
造函数其实和普通函数本质上并无区别,唯一的区别有两个: 函数首字母大写,这个区别只是约定俗成的,便于区分.你实在要小写定义构造函数也完全没问题,所以这个区别可以忽略. 构造函数的调用需要用new操作符,而普通函数的调用又分很多种,但是都不会用到new操作符.所以,构造函数和普通函数的区别就在这个new操作符里,现在让我们来好好研究一下这个new操作符. 用new操作符创建对象时发生的事情: (1)创建一个新对象: (2)将构造函数的作用域赋给新对象(因此this就指向了这个新对象): (3)执行…
看了阮一峰的网络日志(http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_inheritance.html),记录一下构造函数继承的几种方式. 1.构造函数绑定 使用call或apply方法,将父对象的构造函数绑定在子对象上,即在子对象构造函数中加一行:Parent.apply(Child, arguments): 2.使用prototype模式 第一步(删除Child的prototype 对象原先的值,赋予一个新值…
注:普通对象与函数对象 var o1 = {}; var o2 =new Object(); var o3 = new f1(); function f1(){}; var f2 = function(){}; var f3 = new Function('str','console.log(str)'); console.log(typeof Object); //function console.log(typeof Function); //function console.log(typ…
先来个普通对象 var duixiang={ a:"111", b:function (s) { return s+"886"; } }; console.log(duixiang.a); console.log(duixiang.b(duixiang.a)); 来一个构造函数,有this关键字 var constructor=function () { this.a="ok"; this.outlet=function(s){ return t…