javascript编程开发修炼之道

 

提要文摘附注: 本文的核心内容是围绕javascript前端开发的编程技术要素,来深入地探讨编写高质量的javascript代码的方法、技巧、规范和最佳实践,从而为编写易于维护的Web前端代码打下坚实的基础。

作者:贵源网络

1.javascript基础类库

2.创建静态对象 var obj = {}、window['obj']={};

3.创建实例对象 function fn(){} fn.prototype = {}

4.function对象自执行函数(function(){})()

5.判断对象类型 typeof(obj) == 'number|string|boolean|object|function|undefined'

6.JSON数据传输

7.数组与对象并用

8.ajax数据交互

9.创建common文件

10.类库特效开发

11.运算符与简化写法

12.cookie记录

13.url参数操作

14.正则表达示/expression/

15.扩展内置对象

______________________________________________________

http://www.36ria.com/demo/hover/demo.html

1.javascript基础类库

jQuery.js/jQuery.form.js/jQuery.cookie.js  JSON.js  FIS.js

2.创建静态对象 var obj = {}、window['obj']={} 、var obj=new Object();

创建对象:

以下结果等价

var obj = {}
obj.id =1

obj.name=‘sn’

window['obj']={}
obj.id =1

obj.name=’sn’

var obj = 
new Object()
obj.id =1

obj.name=’sn’

var obj = {

id:1,
 name:’sn’

}

window[‘obj’]={

id:1,
    name:’sn’

}

主要用途:定义全局变量、当做函数参数调用

3.创建实例对象
function fn(){} fn.prototype = {}

以下结果等价

function fn(){}
fn.prototype.get=function(){}

fn.prototype.set=function(){}

function fn(){}

fn.prototype={

get:function(){}
    set:function(){}

}

主要用途:复杂动能的实现

4.function对象自执行函数(function(){})()

以下结果等价

(function(){

})()

(function(){

}())

(function(){
}).call(this)

!function(){}
void function(){}

主要用途:复杂动能的实现

5.判断对象类型 typeof(obj) == 'number|string|boolean|object|function|undefined'

typeof 是一个一元运算,放在一个运算数之前,运算数可以是任意类型。

它返回值是一个字符串,该字符串说明运算数的类型。


"undefined"——如果这个值未定义或未初始化时;


"boolean"——如果这个值是布尔值;


"string"——如果这个值是字符串;


"number"——如果这个值是数值,
1)true和false将分别被替换为1和0
2)如果是null值,返回0
3) 如果是undefined,返回NaN


"object"——如果这个值是对象或null;


"function"——如果这个值是函数;

6.JSON数据传输

JSON序列化和反序列化

JSON是“名值对”的集合。结构由大括号'{}',中括号'[]',逗号',',冒号':',双引号'“”'组成,包含的数据类型有Object,Number,Boolean,String,Array, NULL等。

7.数组与对象并用

8.ajax数据交互

//所有 AJAX 请求设置默认

jQuery.ajaxSetup({

dataType: "json",

type: "POST"

});

//当 AJAX 请求开始时,显示“加载中”的指示

jQuery(document).ajaxStart(function () {

jQuery.colorbox({

html: '<div id="loader"><img src="oading.gif"/><span>

正在提交请求...</span></div>',

opacity: 0.3,

overlayClose: false,

escKey: false,

close: ""

})

});

9.创建common文件

实现公共方法的文件,此部分可以由自己平时的积累得到或是知复制别人的代码;

10.类库特效开发

/* 1.键盘提交 */

var form = this.form =
$("#stepForm");

this.form.bind("keypress",
function(event) {

var
key_code = event.keyCode;

if(key_code
== "13" || key_code == 13) {

me.submit();

return
false

}

});

11.运算符与简化写法

12.cookie记录

jQuery.cookie.js

13.url参数操作

14.正则表达示/expression/

15.扩展内置对象

1)使用jQuery库扩展(Math、String、Array、Number)

jQuery.extend(Math, {})

2)扩展jQuery对象

jQuery.extend({});

3.对象合并

jQuery.extend(true, C, {})

jQuery.extend(C, {})

javascript编程思想的更多相关文章

  1. 淡扯javascript编程思想

    一.面向对象-OOD   虽然js面向对象的编程思想已经老话常谈了,但了为了文章的完整性,我还是把它加了进来,尽量以不太一样的方式讲述(虽然也没什么卵不一样的). 1.面向对象,首先得有类的概念,没有 ...

  2. 面向对象编程思想(前传)--你必须知道的javascript

    在写面向对象编程思想-设计模式中的js部分的时候发现很多基础知识不了解的话,是很难真正理解和读懂js面向对象的代码.为此,在这里先快速补上.然后继续我们的面向对象编程思想-设计模式. 什么是鸭子类型 ...

  3. 面向对象编程思想(前传)--你必须知道的javascript(转载)

    原文地址:http://www.cnblogs.com/zhaopei/p/6623460.html阅读目录   什么是鸭子类型 javascript的面向对象 封装 继承 多态 原型 this指向 ...

  4. Java编程思想 (1~10)

    [注:此博客旨在从<Java编程思想>这本书的目录结构上来检验自己的Java基础知识,只为笔记之用] 第一章 对象导论 1.万物皆对象2.程序就是对象的集合3.每个对象都是由其它对象所构成 ...

  5. Javascript编程模式(JavaScript Programming Patterns)Part 1.(初级篇)

    JavaScript 为网站添加状态,这些状态可能是校验或者更复杂的行为像拖拽终止功能或者是异步的请求webserver (aka Ajax). 在过去的那些年里, JavaScript librar ...

  6. 浅谈前端JavaScript编程风格

    前言 多家公司和组织已经公开了它们的风格规范,详细可參阅jscs.info,以下的内容主要參考了Airbnb的JavaScript风格规范.当然还有google的编程建议等编程风格 本章探讨怎样使用E ...

  7. JAVA编程思想(第四版)学习笔记----4.8 switch(知识点已更新)

    switch语句和if-else语句不同,switch语句可以有多个可能的执行路径.在第四版java编程思想介绍switch语句的语法格式时写到: switch (integral-selector) ...

  8. 《Java编程思想》学习笔记(二)——类加载及执行顺序

    <Java编程思想>学习笔记(二)--类加载及执行顺序 (这是很久之前写的,保存在印象笔记上,今天写在博客上.) 今天看Java编程思想,看到这样一道代码 //: OrderOfIniti ...

  9. #Java编程思想笔记(一)——static

    Java编程思想笔记(一)--static 看<Java编程思想>已经有一段时间了,一直以来都把笔记做在印象笔记上,今天开始写博客来记录. 第一篇笔记来写static关键字. static ...

随机推荐

  1. 基於tiny4412的Linux內核移植 --- 实例学习中断背后的知识(2)

    作者:彭东林 邮箱:pengdonglin137@163.com QQ:405728433 平台 tiny4412 ADK Linux-4.9 概述 前面一篇博文基於tiny4412的Linux內核移 ...

  2. AutoMapper在MVC中的运用03-字典集合、枚举映射,自定义解析器

    本篇AutoMapper使用场景: ※ 源字典集合转换成目标字典集合 ※ 枚举映射 ※ 自定义解析器 ※ 源中的复杂属性和Get...方法转换成目标属性 源字典集合转换成目标字典集合 □ Domain ...

  3. delphi 实现文件上传下载

    unit UpDownFile; interface uses Windows, Classes, Idhttp, URLMon, IdMultipartFormData; const UpUrl = ...

  4. Delphi 包的设计思想及它与PAS、BPL、DCU、DLL、OXC的关系

    一.Delphi中各种文件的介绍,及其关系. OXC: ActiveX控件.会被安装到某一个组件包DPK中,在Imports中会创建PAS.DCU.DCR三个文件. DLL: 动态链接库文件,它的Ex ...

  5. C#编程(三十七)----------结构比较

    结构比较 数组和元组都实现接口IStructuralEquatable和IStructuralComparable.这两个接口不仅可以比较引用,还可以比较内容.这些接口都是显示实现的,所以在使用时需要 ...

  6. Base64 JAVA后台编码与JS前台解码(解决中文乱码问题)

    中文通过Java后台进行Base64编码后传到前台,通过JS进行Base64解码时会出现中文乱码的问题,被这个问题也是困扰了几天,使用jquery.base64.js只能转码非中文字符,经过搜集各种方 ...

  7. 暗影猎人第一二季/全集Shadowhunters迅雷下载

    <暗影猎人>该剧根据小说<致命契约>(The Mortal Instruments)改编,是电影<圣杯神器:骸骨之城>的续篇.故事描述少女Clary Fray(Ka ...

  8. 获得assets文件夹中文件内容

    /** * @param fileName * @return assets中文件的字符串 */ public String getFromAssets(Context context, String ...

  9. SQLite中的事务操作

    关于SQLite事务可以解决一些问题,比如你要插入两个数据,可以将两个数据作为同一个事务进行插入,这样如果第二个数据错误了,便自动执行回滚操作,第一个数据也不会插入成功,保证了数据的同步! 一.实际的 ...

  10. SearchView的最简单的使用方式

    SearchView顾名思义就是一个搜索视图,和之前讲解的自动匹配的输入框类似.只不过他有自己特有的监听器,并且可以实时得到用户输入的结果.对于SearchView这个控件,我强烈建议将其放在Acti ...