`
cumtheima
  • 浏览: 253308 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论
阅读更多

 

Web前端开发和JS面向对象编程分享

 

 

一、前端开发的重要性

1. Web2.0、AJAX、JSON、用户体验

2. HTML5、微网、移动互联网

3. 前端MVC框架:Backbone.js

4. 服务器端Javascript:Node.js

5. Node.js + Jquery Mobile + HTML5 、CSS3 + MongDB

二、工欲善其事,必先利其器

1. Firefox插件

    (1)Firebug

集HTMLCSS查看和编辑、Javascript调试、网络状况监视器于一体

(2)Page Speed(基于Firebug)

来评估网页的性能,并获得如何改进性能网页载入速度的建议。Page Speed能自动为用户优化图像,提供可以发布在网页上的压缩图片,它也能识别JS和CSS载入问题,帮助开发者减少浏览者等待网页展示的时间。

(3)YSlow(基于Firebug)

对网站的页面进行分析,并告诉你为了提高网站性能,如何基于某些规则而进行优化并为每一个规则产生一个整体报告,如果页面可以进行优化,则会列出具体的修改意见。

 

Yslow-23条规则:

    http://baike.baidu.com/link?url=g066BL1gqe6RnzN-bJoCjrbLeDrEjRQh_u8x3haH5NuhDtsrzt8ZvjgOfnMsOBuibky8Oqt1H9gUwdsK7TrwH_

   (4)Poster(AJAX)

可以模拟各种http请求,并详细设置请求参数,比如http header,parameter等。

(5)Web Developer Toolbar


 

  (6)解雇IE(fire IE)

是一款仿搜狗浏览器的Firefox双核扩展,能够自动切换IE内核!

2. 前端工具

(1)FSCapture


(2)IETester



 

(3)IE8IE9IE10浏览器(按F12调出)

设置兼容模式,IE标准可以多IE各版本测试



(4) 响应式设计视图

Firefox浏览器--工具--Web开发者--响应式设计视图



(5)文本编辑器

a)Notepad++

 

b)Sublime Text 2

备注:你还在用如“UltraEdit、EditPlus”等文本编辑器吗?你Out了!

(6)截图工具Snagit



  

三、Javascript面向对象编程

1. 使用外部JSCSS

2. 延迟加载JS脚本

(1)脚本置于<body>最底部

(2)defer属性(在script上添加)

//defer作用:文档加载完毕后再执行脚本【但是:只有IE浏览器支持】

<script type="text/javascript" defer="defer" src="js/jquery.js"></script>

3.压缩jscss

JSCSS压缩工具:YUICompressor

4.headjs:能使JS并发下载(但是顺序执行)

例子:

<script src="/js/head.min.js"></script>

 

head.load(["file1.js", "file2.js"]);

head.load({ label1: "file1.js" }, { label2: "file2.js" }); 

head.load(["file1.js", "file2.js"], function() {});

 

参考:

http://headjs.com/

http://headjs.com/site/api/v1.00.html

5.自调用匿名函数(块级作用域)

(function(){

 //使用匿名函数封闭每一个页面中的js代码

})();

好处:

通过定义一个匿名函数,创建了一个“私有”的命名空间,该命名空间的变量和方法,不会破坏全局的命名空间。

6.JS命名空间和模块化

1JS模块化


 (2)JS命名空间

比如approvalList.js文件:

 

/**

 *  approvalList.js <br>

 *  审批列表页面对于的JS

 */

(function(){

 

// 审批列表

var approvalList = {

 

add : function(){

this.showList();

},

showList : function(){

},

im : {

showList : function(){

}

}

};

 

})();

 

// 如何调用

approvalList.add();

approvalList.showList ();

approvalList.im.showList ();

 (3)使用prototype扩展对象方法

比如approvalList.js文件:

 

/**

 *  approvalList.js <br>

 *  审批列表页面对于的JS

 */

(function(){

 

// 审批列表

var approvalList = approvalList  ||  {};

 

approvalList .prototype.add = funtion(){

 

};

 

})();

 

// 如何调用

approvalList.add();

7. 前端解耦

(1)使用jquery绑定事件和单独jscss文件解耦

(2)使用“前端MVC框架: Backbone.js”解耦

四、Javascript注意点

1. 函数参数传递:使用对象形式

比如:

function1({name:gxw,age:28});

或者

var args1 = {name:gxw,age:28};

function1(args1);

 

备注:alert(arguments.length); //输出参数的个数

2. 避免多字符串用+号连接

1)例如下列情况就会出现错误

var str3="3.14";

document.write(str3 - 1);  // 如果是减法他回自动将字符串转成数字  

document.write(str3 + 1);  // 加法会当成字符串的拼接操作

(2)使用Arrayjoin()方法进行连接字符串

var arr = [];

arr.push(aaa);

arr.push(bbb);

 

document.write(arr.join(“”)); 

3. 定义对象用{},定义数组用[]

4.存储常用的值

多次使用同一个值时,可以将其存储在局部变量中提高访问速度

5. 使用“=== !==”进行判断

==用于一般比较 // ==在比较的时候可以转换数据类型

===用于严格比较 // ===严格比较,只要类型不匹配就返回flase

6. Javascript 中的false0nullundefined和空字符串对象

(1)类型

//假值

alert(typeof(false) === 'boolean');

alert(typeof(0) === 'number');

alert(typeof("") === 'string');

 

//空值

alert(typeof(null) === 'object');

alert(typeof undefined === 'undefined');    

 

//空对象

alert(typeof({})==="object");

alert(typeof([])==="object");

(2)== 比较

alert(false == undefined);//flase

alert(false == null);//flase

alert(false == {});//flase

alert(false == []);//flase

alert(false == 0); //true

alert(false == "");//true

alert(null == undefined);//true

(3)=== 比较

alert(false === undefined);//flase

alert(false === null);//flase

alert(false === 0); //false

alert(false === "");//flase

alert(false === {});//flase

alert(false === []);//flase

alert(null === undefined);//flase

(4)if语句中

//假值

if(false){}  //false

if(0){}    //false

if(""){}    //false

 

//空值

if(undefined){}  //false

if(null){}       //false

 

//空对象

if({}){}      //true

if([]){}      //true

建议:

a).true都可以用1来替换,而false可以用0来替换

b).if(!oTest){  //do something  }  // undefined null false""0

7. eval的使用

1eval1

//eval 他是把一个字符串解析成一个方法并且调用  

var str = "var show = function(){alert(100)}()";  

eval(str);

2eval2

//数据库会返回一个字符串(长得像javaScrpit数组)  

var a = "[1,2]";  

var array = eval(a);  

for (var i = 0; i < array.length; i++) {  

alert(array[i])  

}

8. 学会使用js链式调用

/**

 * 从一个实例引出立案时调用的需求

 */

(function(){

//创建一个cat

function Cat(name){

this.name = name;

this.run = function(){

document.write(name+ " start run");

return this;

}

this.sing = function(){

document.write(name+ " start sing");

return this;

}

}

 

//测试

var c = new Cat("abc");

c.run().sing();

})();

9. 禁止在函数内不使用var申明变量

function outerFun(){

       a =0;// 没有使用var申明,就是全局变量了

       alert(a);  

    }

10. 谨慎使用闭包

1)闭包会使函数中的变量保存在内存中

由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。2)闭包会在父函数外部改变父函数内部变量的值

如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。

五、Jquery注意点

1. 总是使用#Id去寻找元素

$('div#content')  (错的)

$('#content')  (对的)

2. class前面使用tags

$('input.on')    (对的)

3. 更好的利用链

$(#id1).css().click();

4. 限制直接对DOM多次操作

组合成字符串,一次性操作DOM

5. 事件委托(冒泡事件)的两面性

1)多个元素使用同一事件,在父元素上绑定事件

2)只有一个元素使用事件,阻止事件冒泡(return false;

event.stopPropagation(); // 事件停止冒泡到,即不让事件再向上传递到document,但是此事件的默认行为仍然被执行,如点击一个链接,调用了event.stopPropagation(),链接仍然会被打开。

 

event.preventDefault(); // 取消了事件的默认行为,如点击一个链接,链接不会被打开,但是此事件仍然会传递给更上一层的先辈元素。

 

return false; // 相当于同时调用了event.stopPropagation()event.preventDefault(),事件的默认行为不会被执行,事件也不会冒泡向上传递。

六、Javascript调试

1.alert() 

2.console.log() firebug内置对象)

    一般信息console.info()

出错信息console.debug()

警告提示console.warn()

错误提示console.error()

 

详见:http://gaoxianwei.iteye.com/blog/2077267

3.Firebug 的调试功能

 

(完)

 

 

 

3
0
分享到:
评论
1 楼 dyg540 2015-09-11  
这篇文章不错,值得借鉴参考!

相关推荐

    2021数学建模美赛C题代码.zip

    最全的数学建模美赛C题和代码、大量刷题题库、逻辑清晰易于学习

    这是一个保存Springboot+MyBaits项目的仓库.zip

    springboot框架 一、Spring Boot基础应用 Spring Boot特征 概念: 约定优于配置,简单来说就是你所期待的配置与约定的配置一致,那么就可以不做任何配置,约定不符合期待时才需要对约定进行替换配置。 特征: 1. SpringBoot Starter:他将常用的依赖分组进行了整合,将其合并到一个依赖中,这样就可以一次性添加到项目的Maven或Gradle构建中。 2,使编码变得简单,SpringBoot采用 JavaConfig的方式对Spring进行配置,并且提供了大量的注解,极大的提高了工作效率,比如@Configuration和@bean注解结合,基于@Configuration完成类扫描,基于@bean注解把返回值注入IOC容器。 3.自动配置:SpringBoot的自动配置特性利用了Spring对条件化配置的支持,合理地推测应用所需的bean并自动化配置他们。 4.使部署变得简单,SpringBoot内置了三种Servlet容器,Tomcat,Jetty,undertow.我们只需要一个Java的运行环境就可以跑SpringBoot的项目了

    课设&大作业-毕业设计精品课程网站,采用的技术是 SSM 框架和 Shiro.zip

    【资源说明】【毕业设计】 1、该资源内项目代码都是经过测试运行成功,功能正常的情况下才上传的,请放心下载使用。 2、适用人群:主要针对计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、数学、电子信息等)的同学或企业员工下载使用,具有较高的学习借鉴价值。 3、不仅适合小白学习实战练习,也可作为大作业、课程设计、毕设项目、初期项目立项演示等,欢迎下载,互相学习,共同进步!

    c#做的综合上位机,服务于freescale智能车&amp;电子设计.zip

    c#做的综合上位机,服务于freescale智能车&amp;电子设计.zip

    tensorflow-gpu-2.7.2-cp39-cp39-manylinux2010-x86-64.whl

    bert

    Python使用 LSTM循环神经网络预测风力发电厂中风机产生的功率项目源码+数据集.zip

    详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;

    Java本科毕业设计NBA球员数据管理系统源码.zip

    高分设计源码,详情请查看资源内容中使用说明 高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明

    基于机器学习的内核恶意代码检测研究

    一篇基于机器学习的内核恶意代码检测研究,传统的恶意代码检测分析已经无法满足现状了,本文指出了其不足,并使用机器学习算法模型进行训练测试,通过一些特征检测达到了很高的准确率

    yue-library是一个基于SpringBoot封装的增强库,提供丰富的Java工具类库.zip

    springboot框架 一、Spring Boot基础应用 Spring Boot特征 概念: 约定优于配置,简单来说就是你所期待的配置与约定的配置一致,那么就可以不做任何配置,约定不符合期待时才需要对约定进行替换配置。 特征: 1. SpringBoot Starter:他将常用的依赖分组进行了整合,将其合并到一个依赖中,这样就可以一次性添加到项目的Maven或Gradle构建中。 2,使编码变得简单,SpringBoot采用 JavaConfig的方式对Spring进行配置,并且提供了大量的注解,极大的提高了工作效率,比如@Configuration和@bean注解结合,基于@Configuration完成类扫描,基于@bean注解把返回值注入IOC容器。 3.自动配置:SpringBoot的自动配置特性利用了Spring对条件化配置的支持,合理地推测应用所需的bean并自动化配置他们。 4.使部署变得简单,SpringBoot内置了三种Servlet容器,Tomcat,Jetty,undertow.我们只需要一个Java的运行环境就可以跑SpringBoot的项目了

    node-v8.16.2.tar.xz

    Node.js,简称Node,是一个开源且跨平台的JavaScript运行时环境,它允许在浏览器外运行JavaScript代码。Node.js于2009年由Ryan Dahl创立,旨在创建高性能的Web服务器和网络应用程序。它基于Google Chrome的V8 JavaScript引擎,可以在Windows、Linux、Unix、Mac OS X等操作系统上运行。 Node.js的特点之一是事件驱动和非阻塞I/O模型,这使得它非常适合处理大量并发连接,从而在构建实时应用程序如在线游戏、聊天应用以及实时通讯服务时表现卓越。此外,Node.js使用了模块化的架构,通过npm(Node package manager,Node包管理器),社区成员可以共享和复用代码,极大地促进了Node.js生态系统的发展和扩张。 Node.js不仅用于服务器端开发。随着技术的发展,它也被用于构建工具链、开发桌面应用程序、物联网设备等。Node.js能够处理文件系统、操作数据库、处理网络请求等,因此,开发者可以用JavaScript编写全栈应用程序,这一点大大提高了开发效率和便捷性。 在实践中,许多大型企业和组织已经采用Node.js作为其Web应用程序的开发平台,如Netflix、PayPal和Walmart等。它们利用Node.js提高了应用性能,简化了开发流程,并且能更快地响应市场需求。

    微信小程序 仿百度小说小程序 看小说小程序 实现源码

    微信小程序 仿百度小说小程序 看小说小程序 实现源码 微信小程序是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或搜一下即可打开应用。对于开发者而言,小程序开发门槛相对较低,难度不及APP开发,能够满足简单的基础应用,适合生活服务类线下商铺以及非刚需低频应用的转换。 下面是一个仿百度小说小程序的简单介绍,用于说明其功能和特点: --- **微信小程序:仿百度小说阅读器** 在这个快节奏的时代,人们越来越倾向于利用碎片化时间来阅读。微信小程序提供了一个便捷的平台,使得用户可以在微信内部直接阅读小说,无需切换应用,极大地提升了阅读体验。本小程序仿照百度小说的界面和功能设计,为用户提供了一个简洁、直观的阅读环境。 主要功能包括: 1. **海量书库**:集成了数千本流行小说资源,涵盖玄幻、都市、言情、历史等多个分类。 2. **智能搜索**:用户可以通过书名或作者进行快速搜索,轻松找到想要阅读的小说。 3. **阅读设置**:提供字体大小、背景颜色、夜间模式等个性化设置,适应不同用户的阅读习惯。 4. **书签功能**:用户可以标记重要章节,方便下次

    基于spring-boot dubbox搭建的java分布式系统的前端管理.zip

    springboot框架 一、Spring Boot基础应用 Spring Boot特征 概念: 约定优于配置,简单来说就是你所期待的配置与约定的配置一致,那么就可以不做任何配置,约定不符合期待时才需要对约定进行替换配置。 特征: 1. SpringBoot Starter:他将常用的依赖分组进行了整合,将其合并到一个依赖中,这样就可以一次性添加到项目的Maven或Gradle构建中。 2,使编码变得简单,SpringBoot采用 JavaConfig的方式对Spring进行配置,并且提供了大量的注解,极大的提高了工作效率,比如@Configuration和@bean注解结合,基于@Configuration完成类扫描,基于@bean注解把返回值注入IOC容器。 3.自动配置:SpringBoot的自动配置特性利用了Spring对条件化配置的支持,合理地推测应用所需的bean并自动化配置他们。 4.使部署变得简单,SpringBoot内置了三种Servlet容器,Tomcat,Jetty,undertow.我们只需要一个Java的运行环境就可以跑SpringBoot的项目了

    Android毕业论文开发记单词app源码.zip

    高分设计源码,详情请查看资源内容中使用说明 高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明高分设计源码,详情请查看资源内容中使用说明

    市政道路电力照明、通信管道工程施工方案最新版.doc

    市政道路电力照明、通信管道工程施工方案最新版.doc

    2016管理类联考199综合能力全国硕士研究生招生考试真题.pdf

    考研管理类联考综合能力答案解析,考研真题,考研历年真题,考研管理类联考历年真题,真题解析。

    2017管理类联考199综合能力全国硕士研究生招生考试真题.pdf

    考研管理类联考综合能力答案解析,考研真题,考研历年真题,考研管理类联考历年真题,真题解析。

    2011管理类联考199综合能力全国硕士研究生招生考试解析.pdf

    考研管理类联考综合能力答案解析,考研真题,考研历年真题,考研管理类联考历年真题,真题解析。

    C++基于Qt+OpenCV+Dlib的人脸识别GUI系统源码.zip

    详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;

    python实现基于LSTM神经网络对道路通行时间的预测源码.zip

    详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;详情请查看资源内容中使用说明;

    YOLOv5+dlib+pyqt5疲劳驾驶数据集和疲劳驾驶检测识别系统源码.zip

    YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明

Global site tag (gtag.js) - Google Analytics