javascript 的 scope
myhere
// JavaScript 脚本,解析型语言
//
var ABCD = function(){
var pub = {};
var pri = {};
pri.name = "myhere";
pri.age = 23;
//var ABCDE;
pub.setName = function( newName){
pri.name = newName;
};
// 这里 pub.getName 被赋值为一个函数,就是定义一个函数
// 这个函数并没有运行,这个函数中的变量(不管是 local 还是 global 都不会被替换为他的值)
// 因此这个 pri.name 还是一个变量,是动态的
pub.getName = function(){
return pri.name;
}
// 这里 pub.N 是一个值,是函数的返回值
// 而且这个值是不会随 pri.name 的改变而改变
// 因为 pub.N 是匿名函数以 pri.name 为参数调用匿名函数后的返回值
// 这个 pub.N 只能是程序运行到这时的 pri.name 值
// pub.N 也可以通过 ABCD.N 来改变
pub.N = function( e){
return e;
}( pri.name );
pub.setAge = function( newAge){
pri.age = newAge;
}
pub.getAge = function(){
return pri.age;
}
pub.setOK = function()
pub.setA = function( s){
ABCDE = s;
}
pub.getA = function(){
return ABCDE;
}
return pub;
}(); // 直接运行匿名函数,ABCD 是匿名函数的返回值,即匿名函数中的 pub
// 运行到这时并没用定义 ABCDE;
ABCD.setA( 'boy');
// 运行到这时定义 ABCDE,他的作用域是 global scope,通过 window['ABCDE'] 可以获得,
// ABCDE 与 pri( 匿名函数中的) 的作用域不一样,pri 只有通过 ABCD 的接口可以访问
// 因此 ABCD 形成一个 scope。pub 相当于 php 中的 public,pri 相当于 private
//
// 如果在匿名函数中定义 ABCDE,则他的作用域就不是 global scope 了,他就和 pri 是同一个作用域了,属于 local scope
//
// javascript 中的函数可以赋值给变量( very important !!!!)。
// 函数有自己的 scope
// 因此一个函数定义中可以嵌套很多函数,而其中的每个函数又有自己的 scope
// 因此可以有很多嵌套的 scope;在这些嵌套的 scope 中,外层的 scope 中的
// 变量在内层 scope 中可见;内层 scope 中的变量在外层 scope 中不可见
//
var a = "a ";
var A = function(){
var pub = {};
var b = "b ";
pub.setValue = function( v){
var c = v || 'c ';
var setAge = function( v){
var d = v || 'd ';
return a + b + c + d;
}
相关文档:
Javascript code prettifier
Javascript 代码美容师
安装使用
下载 文件
在你的文件中包含这儿的脚本和样式表(你要保证这儿的 css 和 js 文件按在你的服务器上, 并且调整在 script 和 link标签中的路径)
<link href="prettify.css" type="text/css" rel="stylesheet" />
<script type="text/javascript" sr ......
方法: string.replace(new RegExp(oldString,"gm"),newString))
gm g=global, m=multiLine,大致上方法就是这样的,可以实现替换全部指定字串
另一个简单的验证JS的方法:
在浏览器地址栏输入
javascript:alert("abcabcabc".replace(new RegExp("a","gm"),"ad&quo ......
在做网站的时候,我们经常需要对尺寸超标的图片进行缩放。
由于浏览器的差异,有些代码某些浏览器工作不正常。
经过研究得到了以下的代码,它可以在IE6,IE8,FireFox中完美地按比例缩放图片而不失真。
//改变图片大小
function resizepic(o)
{
var maxwidth=550; //定义最大宽度
var maxheight=800;&nbs ......
JavaScript时间差计算函数
<mce:script language="javascript"><!--
Date.prototype.dateDiff = function(interval,objDate){
//若參數不足或 objDate 不是日期物件則回傳 undefined
if(arguments.length<2||objDate.constructor!=Date) return undefined;
......
<mce:script type="text/javascript"><!--
function SetCookie(name,value,expire) {
var exp = new Date();
exp.setTime(exp.getTime() + expire);
document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
} ......