JavaScript的DOM操作

JavaScript的DOM操作

(一)DOM是文档对象模型,这种模型为树模型;文档是指标签文档;对象是指文档中每个元素;模型是指抽象化的东西。

(二)Windows对象操作

1.属性和方法

属性(值或者子对象):

子对象:history,location,document,status,menubar,toolbar等。

 

方法(函数)

opener:打开当前窗口的源窗口,如果当前窗口是首次启动浏览器打开的,则opener是null。

dialogArgument:对话框返回值。

事件(事先设置好的程序,被触发)。

 

2.Window.open(“第一部分”“第二部分”“第三部分”“第四部分”)

Window.open的特征参数:

第一部分:写页面地址;

第二部分:_blank打开的方式,在新窗口还是自身的窗口;

第三部分:控制打开的窗口格式,可以写多个,用空格隔开如下:

toolbar=no新打开的窗口无工具条;

menubar=no无菜单栏 status=no无状态栏;

width=100 height=100 宽度高度;

left=100打开的窗口距离左边多少距离;

resizable=no窗口大小不可调;

scrollbars=yes出现滚动条;

location=yes 有地址栏;

Window.open也有返回值,它的返回值是:新打开的窗口对象。

例如:最简单的打开窗口:window.open(“Untitled-1.html”);

打开一个窗口并保存在变量中:var w=window.open();

可以将打开的多个窗口保存在数组w里:

function openW()

{

w[i++]=window.open();

}

3.window.close();关闭当前窗口;

w.close();关闭保存在变量w中的那个窗口;

关闭多个子窗口:先将打开的窗口存入数组内,利用循环将其挨个关闭;

关闭打开当前窗口的源窗口:window.opener.close();

4.间隔与延迟

间隔执行一段代码(函数):window.setInterval(“要执行的代码”,间隔的毫秒数);

清除间隔执行:window.clearInterval(间隔的id);循环一次之后用来清除间隔执行的代码

延迟一段时间执行某一段代码(函数):window.setTimeout(“要执行的代码”,延迟的毫秒数);

清除延迟:window.clearTimeout(延迟的id);清除setTimeout

5.调整页面

window.resizeTo(宽,高);调整页面的宽度和高度;

window.scrollTo(x,y);滚动页面至哪里,y代表纵向滚动。

window.navigate(“url”)跳转至目标页面,在谷歌浏览器下有bug;

window.moveTo(x,y);移动页面至某一位置,位置由x和y决定;

6.模态对话框和非模态对话框

模态对话框(Modal Dialogue Box),是指在用户想要对对话框以外的应用程序进行操作时,必须首先对该对话框进行响应。如单击【确定】或【取消】按钮等将该对话框关闭,它和非模态对话框都是永远置顶的,它们的区别在于当对话框打开时,是否允许用户进行其他对象的操作。

打开模态对话框:window.showModalDialog(“url”,”向模态对话框传的值”,“窗口特征参数”);

特征参数:用分号隔开,像素大小用px。dialogHeight,dialogWidth,center等

打开非模态对话框:window.showModalessDialog(“url”,”向模态对话框传的值”,“窗口特征参数”)

var a=window.dialogArgument;可以用一个参数来获取模态或非模态对话框传递的值。

传递的也可以是一个对象。

例题:

/*主网页*/
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>

<body>
</body>
</html>
<script language="javascript">
var obj = new Object();
obj.name="51js";
window.showModalDialog("a.html",obj,"dialogWidth=200px;dialogHeight=100px");
</script>


/*模态对话框*/
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head>

<body>
</body>
</html>
<script language="javascript">
var obj = window.dialogArguments
alert("您传递的参数为:" + obj.name)
</script>

运行结果:

c

点击确定后

d

关闭模态窗口后才能对主窗口操作。

(三)Window.history对象

window.history.back();页面进行后退;

window.history.forward();页面前进;

window.history.go(n);n如果是正数则代表前进n个页面,n如果是负数则代表后退n个页面,一般常用这一种。

(四)window.location对象

location地址栏

var s=window.location.href;获取当前页面的地址

window.location.href=”http:www.baidu.com”修改页面地址,会跳转页面

window.location.hostname:主机名,域名,网站名,可用变量接收

window.location.pathname:路径名,可用变量接收

(五)window.status对象

status状态栏,可以给状态栏添加要显示的文字

window.status=”要在状态栏显示的内容”;设置状态栏文字

(六)window.document对象

1.找到元素:

(1)document.getElementByID(“id”);根据id找,最多找一个;

var a=document.getElementByID(“id”);将找到的元素放在变量中;

 

document.getElementsByName(“name”);根据name找,找出来的是数组;(用于表单元素)

document.getElementsByClassName(“name”);根据classname找,找出来的是数组;

document.getElementsByTagName(“name”);根据标签名找,找出来的是数组;

2.操作内容:

(1)给表单元素:

①获取内容:

alert(a.innerHTML);标签里的html代码和文字都获取了

alert(a.innerText);只取里面的文字

alert(a.outHTML);包括标签本身的内容(简单了解)

 

(注意:innerHTML等只能用于双标签,button等单表签不能使用)

例题:

a

②设置内容:

a.innerHTML=”<font color=red>hello world</font>”;引号里的格式设置有效,原先内容会被替换

a.innerText=””;引号内的内容当作字符串处理,原样呈现。

清空内容:赋值个空字符串。

⑵表单元素:

①获取内容,有三种获取方式:

用id获取

用Name

var t=document.fl.tl;      id为fl的form表单id为tl的元素

 

alert(t.value);

alert(t.innerHTML);获取<textarea>这里的值</textarea>

(innerHTML只能用于双标签)

②设置内容:t.value=”内容改变”;

 

一个小知识点:

<a herf=”www.baidu.com”onclick=”return false”>转向百度</a>;加了return false则不会跳转,默认是return true会跳转。按钮也一样,如果按钮中设置return false则不会进行提交,利用这个可以对提交跳转进行控制。

 

3.操作属性

首先利用元素的id找到该元素,存于一个变量中:

var a=document.getElementById(“id”);

然后可以对该元素的属性进行操作:

a.setAttribute(“属性名”,“属性值”);设置一个属性,添加或更改都可以,可以联想一下C#中设置类的属性;

a.getAttribute(“属性名”);获取属性的值;

a.removeAttribute(“属性名”);移除一个属性。

例题:做一个问题,如果输入的答案正确则弹出正确,错误弹出错误;

这里给text里面设置了一个daan属性,里面存了答案,点击检查答案的时候check输入的内容和答案是否一样。

<body>
<form>
中华民国成立于那一年?
<input type="text" daan="1912年" value="" id="t1" name="t1"/>
<input type="button" onclick="check()" id="t2" value="检查答案"/>

</form>
</body>
</html>

<script language="javascript">

function check()
{
    //注意,如果将下面前两行代码写在函数外面,则c的值会一直为空,在调用函数时(填写文本框后),c才能取到文本框内输入的值,
    var a=document.getElementById("t1");
    c=a.value;d=a.daan;
    if (c==d)
    {
        alert("正确");}
    else
    {
        alert("错误");}

}

</script>

b

 

4.操作样式

样式为CSS中的样式,所有的样式都可以用代码进行操作。

首先利用元素的id找到该元素,存于一个变量中:

var a=document.get#lementById(“id”);

然后可以对该元素的属性进行操作:

a.style.样式=“”;操作此id元素样式的属性。

document.body.style.backgroundColor="颜色";整个窗口的颜色。

例题:展示图片的自动和手动切换

 

<style type="text/css">
.show{
    width:201px;
    height:178px;
    background-color:#0F3;
    background-image:url(img/1.png);
    }
.page{
    width:40px;
    height:30px;
    background-color:#FC0;
    }
.page1{
    float:left;
    position:relative;
    top:70px;}
.page2{
    float:right;
    position:relative;
    top:70px;}

</style>
</head>

<body>
<div class="show" id="show">
    <div class="page page1"  onclick="diyUp()">上页</div>
    <div class="page page2"  onclick="diyDown()">下页</div>
</div>
</body>
</html>

<script language="javascript">
var pic=new Array();
pic[0]="url(img/1.png)";
pic[1]="url(img/2.png)";
pic[2]="url(img/3.png)";
//用id获取普通标签
var show=document.getElementById("show");
n=0;m=0;

//自动换图
function autoChange()
{
    if (m==0)
    {
    
        n++;
        
        if(n<=2)
        {
        show.style.backgroundImage=pic[n];}
        else
        {
            n=0;
            show.style.backgroundImage=pic[n];
            }    
        
        window.setTimeout("autoChange()",3000);
    }
}
    
    window.setTimeout("autoChange()",3000);

//手动换图 换上一张
function diyUp()
{
    m=1;
    n--;
    if(n>=0)
    {
        show.style.backgroundImage=pic[n];
    }
    else
    {
        n=2;
        show.style.backgroundImage=pic[n];
    }
    
}
//换下一张
function diyDown()
{
    m=1;
    n++;
    if(n<=2)
    {
        show.style.backgroundImage=pic[n];
    }
    else
    {
        n=0;
        show.style.backgroundImage=pic[n];
    }
}
</script>

c

5.相关元素操作

var a=document.getElementById(“id”);找到a

var b=a.nextSibling;     找a的下一个同辈元素,注意包含空格;

var b=a.previousSibling,找a的上一个同辈元素,注意包含空格;

var b=a.parentNode,找a的上一个父级元素;

var b=a.childNodes;     找出来的是数组,找a的下一级子元素;

var b=a.firstChild;    第一个子元素,lastChild最后一个,childNodes[n]找第几个

alert(nodes[i] instanceof Text);判断是不是文本,是则返回true,不是返回false,用if判断它的值是不是false,可以去除空格。

6.元素的创建、添加、删除:

var a=document.getElementById(“id”);找到a;

创建:var obj=document.createElement(“标签名“);创建一个元素

obj.innerHTML=”hello world”;添加的时候首先需要创建出一个元素。

添加:a.appendChild(obj);向a中添加一个子元素。

a.removeChild(obj);删除一个子元素。

列表中a.selectIndex:选中的是第几个;a.options[a.selectIndex]按下标取出第几个option对象

7.字符串的操作

var s=new String();或var s=”aaaa”;

var s=”hello world”;

alert(s.toLowerCase());转小写      toUpperCase()转大写

alert(s.substring(3,8));从第三个位置截取到第八个位置

alert(s.substr(3,8));从第三个位置开始截取,截取八个字符长度,不写后面的数字是截到最后。

s.split(‘’);将字符串按照指定的字符拆开

s.length是属性

s.indexOf(“wordl”);world在字符串中第一次出现的位置,没有返回-1

s.lastIndexOf(“o”);o在字符串最后一次出现的位置

8.日期时间的操作

var d=new Date();当前时间

var d=new Date(1999,3,2);定义一个时间,1999年4月2日,3要加1

d.getFullYear:取年份;d.getMonth():取月份,取出来的少1;d.getDate():取天;d.getDay();取星期几

d.getHours():取小时;d.getMinutes();取分钟;d.getSecond();取秒;d.setFullYear():设置年份,设置月份的时候注意加1。

9.数学函数的操作

Math.ceil();大于当前小数的最小整数

Math.floor();小于当前小数的最大整数

Math.sqrt();开平方

Math.round();四舍五入

Math.random();随机数,0-1之间

小知识点:外面双引号,里面的双引号改为单引号;

在div里面行高设置和整个外面高度一样,才能用数值居中,居中是行居中。

文本框取出来的值是字符串,需要用parseint()转化为数字

s.match(reg);s代表一个字符串,reg代表一个字符串,两者进行匹配,如果两个字符串不匹配,返回一个null。

 

四、表单验证和事件

㈠表单验证

1.非空验证(去空格)

2.对比验证(跟一个值对比)

3.范围验证(根据一个范围进行判断)

4.固定格式验证:电话号码,身份证号,邮箱,信用卡号等的验证;需要用到正则表达式来进行验证。

5.其它验证

㈡正则表达式

用符号来描述书写规则:/中间写正则表达式/

^:匹配开头,$:匹配结尾;/^e/以ve开头的/ve$/以ve结尾

\d:一个任意的数字

\w:一个任意的数字或字母

\s:任意字符串

{n}:把左边的表达式重复n遍

{m,n}:把左边的表达式重复至少m遍,至多n遍

{m,}把左边的表达式重复至少m遍,至多不限

+:左边的表达式,至少出现一次,至多不限,相当于{1,}

*:左边的表达式,至少出现0次,至多不限,相当于{0,}

?:左边的表达式,至少出现0次,至多出现1次,相当于{0,1}

[a,b,c]:只能取方括号中内容之一

[a-z]或[1-9]:在范围中取其一       [a-z,A-Z]

|:代表或者;():优先级\:转义—“\(\)”这个才是要出现的小括号,需要转义

㈢事件

事件有三要素:事件源、事件数据、事件处理程序

事件冒泡:当元素嵌套的时候,内部元素激发某个事件后,默认情况下外部元素相应的事件也会跟着依次触发可以加return false:是阻止默认操作

onclick:鼠标单击触发

ondbclick:双击触发

onmouseover:鼠标移动上面触发

onmouseout:鼠标离开时触发

onmousemove:鼠标在上面移动时触发

onchange:只要内容改变触发

onblur:失去焦点时触发

onfocus:获得焦点时触发

onkeydown:按键按下的时候触发

onkeyup:按键抬起来的时候触发

onkeypress:事件在用户按下并放开任何字母数字键时发生。但是系统按钮(例如:箭头键、功能键)无法得到识别。

例子:根据正则表达式验证邮箱

function checkmail()

{

var v4=trim(u4.value);

var reg=/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/;

if(v4.match(reg)!=null)

{

imgs4.setAttribute(“src”,”imges/1.png”);

return true;

}

 

else

{

imgs4.setAttrinbute(“src”,”imges/2.png”);

return false;

}

 

常用正则表达式

 

正则表达式用于字符串处理、表单验证等场合,实用高效。现将一些常用的表达式收集于此,以备不时之需。

匹配中文字符的正则表达式: [\u4e00-\u9fa5] 
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了

匹配双字节字符(包括汉字在内):[^\x00-\xff] 
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

匹配空白行的正则表达式:\n\s*\r 
评注:可以用来删除空白行

匹配HTML标记的正则表达式:<(\S*?)[^>]*>.*?</\1>|<.*? /> 
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力

匹配首尾空白字符的正则表达式:^\s*|\s*$ 
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式

匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* 
评注:表单验证时很实用

匹配网址URL的正则表达式:[a-zA-z]+://[^\s]* 
评注:网上流传的版本功能很有限,上面这个基本可以满足需求

匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 
评注:表单验证时很实用

匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7} 
评注:匹配形式如 0511-4405222 或 021-87888822

匹配腾讯QQ号:[1-9][0-9]{4,} 
评注:腾讯QQ号从10000开始

匹配中国邮政编码:[1-9]\d{5}(?!\d) 
评注:中国邮政编码为6位数字

匹配身份证:\d{15}|\d{18} 
评注:中国的身份证为15位或18位

匹配ip地址:\d+\.\d+\.\d+\.\d+ 
评注:提取ip地址时有用

匹配特定数字: 
^[1-9]\d*$ //匹配正整数 
^-[1-9]\d*$ //匹配负整数 
^-?[1-9]\d*$ //匹配整数 
^[1-9]\d*|0$ //匹配非负整数(正整数 + 0) 
^-[1-9]\d*|0$ //匹配非正整数(负整数 + 0) 
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ //匹配正浮点数 
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ //匹配负浮点数 
^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$ //匹配浮点数 
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$ //匹配非负浮点数(正浮点数 + 0) 
^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$ //匹配非正浮点数(负浮点数 + 0) 
评注:处理大量数据时有用,具体应用时注意修正

匹配特定字符串: 
^[A-Za-z]+$ //匹配由26个英文字母组成的字符串 
^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串 
^[a-z]+$ //匹配由26个英文字母的小写组成的字符串 
^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串 
^\w+$ //匹配由数字、26个英文字母或者下划线组成的字符串 
评注:最基本也是最常用的一些表达式

 

 

 

 

 

 

 

 

}

posted @ 2015-02-26 20:01  Valentino  阅读(295)  评论(0编辑  收藏  举报