javascript高级语法学习
可维护的代码意味着:
可读的
一致的
可预测的
看上去就像是同一个人写的
已记录 命名函数表达式
(function fn(){})
他是表达式的原因是因为括号 ()是一个分组操作符,它的内部只能包含表达式 eval('(' + json + ')')
JSON字符串通常被包含在一个圆括号里,会让解析器强制将JSON的花括号解析成表达式而不是代码块 JavaScript核心
1.对象Object
Object是一个属性的集合,并且都拥有一个单独的原型对象[prototype object]. 这个原型对象[prototype object]可以是一个 object或者null值。 2.原型链__proto__
原型链是一个由对象组成的有限对象链用于实现继承和共享属性。
var a = {
x: 10,
calculate: function (z) {
return this.x + this.y + z
}
}; var b = {
y: 20,
__proto__: a
}; var c = {
y: 30,
__proto__: a
}; // 调用继承过来的方法
b.calculate(30); // 60 3.构造函数constructor
自动为创建的新对象设置了原型对象(prototype object) 。原型对象存放于 ConstructorFunction.prototype 属性中 。
// 构造函数
function fn(y) {
this.y = y;
}
// 继承属性"x"
Foo.prototype.x = 10;
var b = new Foo(20);
b.__proto__ === fn.prototype; // true // "fn.prototype"自动创建了一个特殊的属性"constructor",并指向b的构造函数本身
b.constructor === fn; // true
fn.prototype.constructor === fn // true 4.执行上下文
var a = function (e) {
return {
// 暴露公开的成员
add: function (x, y) {
}
};
}
调用:
ar o = new a('e');
o.add(2, 2); 引用全局变量
(function ($) {
调用:$
} (jQuery)); var o = (function ($) {
var my = {name = 'sn'}
return my;
})(jQuery);
调用:o.name 扩展
var o = (function (my) {
my.add = function () {};
return my;
} (obj)); 松耦合扩展
var o = o || {} ;
var o = (function (my) {
return my;
} (jQuery || {})); 克隆与继承
var o = (function (old) {
var my = {},key;
for (key in old) {
if (old.hasOwnProperty(key)) {
my[key] = old[key];
}
}
return my;
} (obj));
子模块
obj.sub = (function () {
var my = {};
return my;
} ());
函数语法
if (typeof Function.prototype.method !== "function") {
Function.prototype.method = function (name, call) {
this.prototype[name] = call;
return this;
};
}
扩展对象
var fn = function (name) {
this.name = name;
}
.method('get',
function () {
return this.name;
})
调用
var a = new fn('p');
a.get();
var app = app || {};
(function () {
app = {
isArray: isArray,
inArray: indexOf
};
} ());
// 第一个参数为要应用的function,第二个参数是需要传入的最少参数个数
function funcArgs(func, minArgs) {
if (minArgs == undefined) {
minArgs = 1;
}
function func(oargs) {
return function () {
// 优化处理,如果调用时没有参数,返回该函数本身
var args = Array.prototype.slice.call(arguments);
var nrgs = oargs.concat(args);
if (nrgs.length >= minArgs) {
return func.apply(this, nrgs);
} else {
//返回该函数本身
return func(nrgs);
}
};
}
return func([]);
}
//定义加法
var plus = funcArgs(function () {
var result = 0;
for (var i = 0; i < arguments.length; ++i) {
result += arguments[i];
}
return result;
}, 2);
//定义减法
var minus = funcArgs(function (x) {
var result = x;
for (var i = 1; i < arguments.length; ++i) {
result -= arguments[i];
}
return result;
}, 2); plus(3, 2) // 正常调用
plus(3) // 偏应用,返回一个函数(返回值为3+参数值)
plus(3)(2) // 完整应用(返回5)
plus()(3)()()(2) // 返回 5
plus(3, 2, 4, 5) // 可以接收多个参数
plus(3)(2, 3, 5) // 同理
//添加方法(函数)
Function.prototype.method = function (name, fn) {
this.prototype[name] = fn;
return this;
};
//给构造函数添加方法
Array.method('filter', function (fn, obj) { var a = []; return a; });
//队列实现
window.Queue = function () { }
window.Queue
.method("add", function (a, b) { return a + b; })
.method("sub", function (a, b) { return a - b; });
//调用
var obj = new window.Queue();
console.log(obj.add(1, 2)); //3
console.log(obj.sub(3, 1)); //2
passport.pop = passport.pop || {};
passport.pop.insertScript = passport.pop.insertScript ||
function (b, a) {
var e = document,
c = e.createElement("script");
c.type = "text/javascript";
c.charset = "UTF-8";
if (c.readyState) {
c.onreadystatechange = function () {
if (c.readyState == "loaded" || c.readyState == "complete") {
c.onreadystatechange = null;
a && a()
}
}
} else {
c.onload = function () {
a && a()
}
}
c.src = b;
e.getElementsByTagName("head")[0].appendChild(c)
};
javascript高级语法学习的更多相关文章
- Swift高级语法学习总结(转)
Swift高级语法学习总结 1.函数 1.1 func funcNmae()->(){} 这样就定义了一个函数,它的参数为空,返回值为空,如果有参数和返回值直接写在两个括号里就可以了 1.2 参 ...
- Swift高级语法学习总结
Swift基础语法学习总结Swift高级语法学习总结Swift语法总结补充(一) 1.函数 1.1 func funcNmae()->(){} 这样就定义了一个函数,它的参数为空,返回值为空,如 ...
- javascript高级实战学习
学习目标: - 理解面向对象开发思想 - 掌握 JavaScript 面向对象开发相关模式 - 掌握在 JavaScript 中使用正则表达式 - typora-copy-images-to medi ...
- JavaScript高级程序设计---学习笔记(一)
今天,2017.3.17开始利用课余时间仔细学习<JavaScript高级程序设计>,将需要掌握的知识点记录下来,争取把书里的所有代码敲一遍并掌握. 1.标识符命名最好是第一个字母小写,剩 ...
- JavaScript高级程序设计学习(四)之引用类型
在javascript中也是有引用类型的,java同样如此. javascript常见也比较常用的引用类型就熟Object和Array. 一个对象和一个数组,这个在前后端分离开发中也用的最多.比如aj ...
- JavaScript高级程序设计学习(三)之变量、作用域和内存问题
这次讲的主要是变量,作用域和内存问题. 任何一门编程语言,都涉及这三个. 变量,比如全局变量,局部变量等,作用域,也分全局作用域和方法作用域,内存问题,在java中就涉及到一个垃圾回收的问题,由于ja ...
- javascript高级程序设计学习笔记
javascript高级程序设计,当枕头书已经好久了~zz 现在觉得自己在js的开发上遇到了一些瓶颈,归根究底还是基础太薄弱,所以重新刷一遍js高程希望有更新的认识. 一.javascript简介 ...
- C++ 高级语法学习与总结(代码实例)
C++11增加了许多的特性,auto就是一个很明显的例子. 还有就是typedid()获取数据变量的类型 看下面简短的代码: atuo: 很像java中的加强for循环..... //获取一个数据 ...
- JavaScript高级程序设计学习(四)之引用类型(续)
一.Date类型 其实引用类型和相关的操作方法,远远不止昨天的所说的那些,还有一部分今天继续补充. 在java中日期Date,它所属的包有sql包,也有util包.我个人比较喜欢用util包的.理由, ...
随机推荐
- javascript:currentStyle和getComputedStyle的兼容写法
currentStyle:获取计算后的样式,也叫当前样式.最终样式. 优点:可以获取元素的最终样式,包括浏览器的默认值,而不像style只能获取行间样式,所以更常用到. 注意:不能获取复合样式如bac ...
- CentOS RabbitMQ 高可用(Mirrored)
原文:https://www.sunjianhua.cn/archives/centos-rabbitmq.html 一.RabbitMQ 单节点 1.1.Windows 版安装配置 1.1.1 安装 ...
- 如何获得ios7系统中的蓝色
最简洁的办法,直接使用下列代码: [UIColor colorWithRed:0.0 green:122.0/255.0 blue:1.0 alpha:1.0] 最彻底的办法: OS7Colors是U ...
- Hybrid App 开发初探:使用 WebView 装载页面
Hybrid App 是混合模式应用的简称,兼具 Native App 和 Web App 两种模式应用的优势,开发成本低,拥有 Web 技术跨平台特性.目前大家所知道的基于中间件的移动开发框架都是采 ...
- End2endIT
"C:\Program Files\Java\jdk1.8.0_112\bin\java" -ea -Didea.test.cyclic.buffer.size=1048576 & ...
- Android5.0新控件RecyclerVIew的介绍和兼容使用的方法
第一部分 RecyclerVIew是一个可以替代listview和Gallery的有效空间而且在support-v7中有了低版本支持,具体使用方式还是规规矩矩的适配器加控件模式.我们先来看看官网的介绍 ...
- Docker存出载入镜像
镜像的存出和载入 如果你的生产环境不能连通互联网,而你又希望从互联网上获取镜像.你就需要借助 docker save命令,可以将镜像导出为 tar 文件.使用 docker load 命令,可以将ta ...
- 析构函数 (C++)
最近发现自己对析构函数的认知有一定的问题,因为之前有在使用placement new时主动调用对象的析构函数,所以觉得析构函数只是个普通的成员函数,调用的时候只会执行自己方法体内的代码内容,而回收内存 ...
- sharepoint list 文档上传和删除
最近项目需要对sharepoint 文件操作,于是自己写了一个简单的工具类分享出来: namespace Microsoft.SharePoint { using System; using Syst ...
- Latex使用的注意事项
CTEX : CTeXDownload latex中的图片格式主要就2种 pdf 和 eps.如果要用pdflatex编译,那么自然选择pdf,如果用latex编译,自然用eps.本人论文中的图片来源 ...