Javascript 技巧日常收集

获取 javascript 时间戳:

var timestamp = Date.parse(new Date());

或者:

var timestamp = (new Date()).valueOf();

以上代码将获取从 1970年1月1日午夜开始的毫秒数。二者的区别是,第一种方法的毫秒位上为全零,即只是精确到秒的毫秒数。

 

-------------------------------------------------------------------------------------------------------------

<script language="javascript">
var patterns = new Object();

//匹配ip地址
patterns.ip = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])(\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])){3}$/;

//匹配邮件地址
patterns.email = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;

//匹配日期格式2008-01-31,但不匹配2008-13-00
patterns.date = /^\d{4}-(0?[1-9]|1[0-2])-(0?[1-9]|[1-2]\d|3[0-1])$/;

/*匹配时间格式00:15:39,但不匹配24:60:00,下面使用RegExp对象的构造方法
来创建RegExp对象实例,注意正则表达式模式文本中的“\”要写成“\\”
*/
patterns.time = new RegExp("^([0-1]\\d|2[0-3]):[0-5]\\d:[0-5]\\d$");

/*verify – 校验一个字符串是否符合某种模式
*str – 要进行校验的字符串
*pat – 与patterns中的某个正则表达式模式对应的属性名称
*/
function verify(str,pat)
{
thePat = patterns[pat];
if(thePat.test(str))
{
return true;
}
else
{
return false;
}
}
</script>

===============================

javascript 和 css 的摆放位置/顺序

1.在<head></head>里面时,javascript放在css的前面,这样css可以与页面内的其他资源一起下载

2.对于不在<head></head>的javascript,放在</body>之前

3.javascript引用资源(比如图片)相对路径是以宿主环境(所被引用的网页比如user.html)所处位置为基准

4.css引用资源(比如图片)相对路径是以.css文件所处位置为基准!

5.当浏览器执行 JavaScript代码时,不能同时做其他任何事情(单一进程),意味着<script>标签每次出现都霸道地让页面等带脚本的解析和执行 (每个文件必须等到前一个文件下载并执行完成才会开始下载),所以头部的JS和CSS用来渲染页面,交互行为(几乎所有)的JS放 在<body>底部;

-------------------------------------------------

IE的条件注释。许多前端总是在抱怨万恶的IE,确实,处理兼容性的问题确实会越来越恶心,可是没有办法,既然没有办法改变,那么请享受...


<!--[if IE]>
<h1>您正在使用IE浏览器</h1>
<![endif]-->
<!--[if IE 5]>
<h1>版本 5</h1>
<![endif]-->
<!--[if IE 5.0]>
<h1>版本 5.0</h1>
<![endif]-->
<!--[if IE 5.5]>
<h1>版本 5.5</h1>
<![endif]-->
<!--[if IE 6]>
<h1>版本 6</h1>
<![endif]-->
<!--[if IE 7]>
<h1>版本 7</h1>
<![endif]-->

-------------------------------------------------

setAttribute方法设置元素类名 : 在jQuery中,直接使用attr()方法即可,可在原生的JS中

element.setAttribute('class','newClassName') //这个是W3C的标准,在兼容W3C标准的浏览器中有效,可是,IE才是国内用户的主旋律
element.setAttribute('className','newClassName') //这样的设置在IE中才能有效
element.className = 'newClassName' //所有浏览器有效(只要支持javascript)

-------------------------------------------------
JavaScript一些总结
一、加载和执行

    浏览器的JavaScript的引擎是编译器层的优化;
    当浏览器执行JavaScript代码时,不能同时做其他任何事情(单一进程),意味着<script>标签每次出现都霸道地让页面等带脚本的解析和执行(每个文件必须等到前一个文件下载并执行完成才会开始下载),所以头部的JS和CSS用来渲染页面,交互行为(几乎所有)的JS放在<body>底部;
    主流浏览器都允许并行下载JS。
    减少外链脚本数量将会改善性能(合并JS)
    任何网站都可以使用一个把制定文件合并处理后的URL来获取任意数量的文件。
    defer属性可延迟脚本(只有IE4 和FF3.5 支持)

二、数据访问

    JavaScript中有四种基本的数据存取位置: 直接量,变量,数组元素(以数字作为索引),对象成员(以字符床作为索引)。
    访问直接量和局部变量的速度最快,相反,访问数组元素和对象成员相对较慢。
    属性或方法在原型链中的位置越深,访问它的速度也越慢。
    通常来说,可以通过吧常用的对象,数组元素,跨越变量保存在局部变量中来改善JavaScript性能。

三、DOM编程

    DOM操作在webkit内核的浏览器速度快,其他的浏览器innerHTML执行快。
    访问和操作DOM是现代WEB应用的重要部分。但每次穿越链接ECMAScript和DOM两个岛屿之间的桥梁都会被收取‘过桥费’.
    要留意重回和重排。
    在IE中:hover会降低响应速度。

四、算法和流程控制

    避免使用for-in循环,除非需要遍历一个属性数量位置的对象。
    了解栈溢出错误。

五、字符串和正则表达式

    回溯既是正则表达式匹配功能的基本组成部分,也是正则表达式的低效之源。

六、快速响应的用户界面

    任何JavaScript任务都不应当执行超过100毫秒。
    Web workers是新版浏览器支持的特性。
    没有什么JavaScript代码会重要到可以影响用户体验的程度.

七、Ajax

    JSON是轻量级的数据格式,解析速度快。
    减少请求数,可通过合并JS和CSS,还有IMG。
    缩短页面加载时间,页面主要内容加载完成后,用Ajax获取那些次要的文件。

八、编程实践

    大多数的时候,没必要使用eval()和Function(),因此最好避免使用它们。至于setTimeout()和setInterval(),建议传入函数而不是字符串来作为第一个参数。
    在JavaScript中创建对象和数组的方法有多种,但使用对象和数组直接量是最快的方式(对象属性和数组项越多,使用直接量的好处就越明显)。
    不要重复工作:延迟加载;条件预加载.
    多使用原生方法,因为更快。

九、构建并部署高性能JavaScript应用

    PV(page view)即页面浏览量或点击量。
    减少页面渲染所需的HTTP请求数,特别是针对那些首次访问网站的用户。
    JavaScript压缩。
    JavaScript缓存。
    使用内容分发网络(CDN)

 

 

posted @ 2011-12-21 14:14  C仔  阅读(262)  评论(0编辑  收藏  举报