阿当的博客











{六月 26, 2009}   含有变量的正则表达式使用方法
我们在写js的时候,很多时候使用到正则表达式都是直接使用类似于 /xxxx/ig的简写格式,可是这种方式xxxx是不能接受变量的。如果xxxx是变量,会动态改变,我们就需要使用new RegExp()来得到一个正则表达式对象了。

例如:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>阿当制作</title>
</head>

<body>
<script type="text/javascript">
var a = "xyz",b="123",c="ab23";
var d = new RegExp(a+"|"+b+"|"+c,"ig");
var e;
e = "---XYZ---ab23---123".replace(d,"ok");
alert(e);
</script>
</body>
</html>

结果可以得到我们想要的"---ok---ok---ok"。

================================================
再来个稍复杂一点的。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>阿当制作</title>
</head>

<body>
<script type="text/javascript">
var url = "http://www.baidu.com?name=adang&sex=mail&address=beijing";
function replace(varname,varvalue){
if(new RegExp(varname+"=.*&").test(url)){
url = url.replace(new RegExp(varname+"=.*?&","g"),varname+"="+varvalue+"&");   
} else if(new RegExp(varname+"=.*$").test(url)){
url = url.replace(new RegExp(varname+"=.*$","g"),varname+"="+varvalue); 
}
}
replace("name","cly");
replace("sex","femail");
replace("address","shanghai");
alert(url);
</script>
</body>
</html>



{六月 24, 2009}   [原创 js] 自定义页面功能

     演示地址:http://www.adanghome.com/tbs/manage.html

      这是一个自定义页面的demo,提供自定义布局,拖动模块位置,添加模块,删除模块,拖动导航,重命名,更改页面样式,更改页面标题等等功能。因为主要想展示DHTML,所以重点在js上,没有用ajax或者cookie记录更改状态。

  



{六月 02, 2009}   编程的幽默

1、“永远要这样写代码,好像最终维护你代码的人是个狂暴的、知道你住在哪里的精神病患者。”

(Martin Golding)

2、“只有两种编程语言:一种是天天挨骂的,另一种是没人用的。”
(Bjarne Stroustrup,C++之父)




about

打造高品质的前端代码

pages
categories
archive
et cetera