zoukankan      html  css  js  c++  java
  • Javascript重要解析

    一、JavaScript 表单验证

    JavaScript 可用来在数据被送往服务器前对 HTML 表单中的这些输入数据进行验证。

    被 JavaScript 验证的这些典型的表单数据有:

    • 用户是否已填写表单中的必填项目?
    • 用户输入的邮件地址是否合法?
    • 用户是否已输入合法的日期?
    • 用户是否在数据域 (numeric field) 中输入了文本?

    1)必填(或必选)项目

    下面的函数用来检查用户是否已填写表单中的必填(或必选)项目。假如必填或必选项为空,那么警告框会弹出,并且函数的返回值为 false,否则函数的返回值则为 true(意味着数据没有问题):

    复制代码
    1 function validate_required(field,alerttxt)
    2 {
    3 with (field)
    4 {
    5 if (value==null||value=="")
    6   {alert(alerttxt);return false}
    7 else {return true}
    8 }
    9 }
    复制代码

    2)E-mail 验证

    下面的函数检查输入的数据是否符合电子邮件地址的基本语法。

    意思就是说,输入的数据必须包含 @ 符号和点号(.)。同时,@ 不可以是邮件地址的首字符,并且 @ 之后需有至少一个点号:

    复制代码
     1 function validate_email(field,alerttxt)
     2 {
     3 with (field)//索引“@” 与 “.”的位置
     4 {
     5 apos=value.indexOf("@")
     6 dotpos=value.lastIndexOf(".") 
     7 if (apos<1||dotpos-apos<2) 
     8   {alert(alerttxt);return false}
     9 else {return true}
    10 }
    11 }
    复制代码

    二、JavaScript HTML DOM

    1.HTML DOM (文档对象模型)

    当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)。

    HTML DOM 模型被构造为对象的树。

    下面有一张图片,放大了自己看!(y老师曾说过:自己要有动手能力和搜索能力)

    通过可编程的对象模型,JavaScript 获得了足够的能力来创建动态的 HTML。

    • JavaScript 能够改变页面中的所有 HTML 元素
    • JavaScript 能够改变页面中的所有 HTML 属性
    • JavaScript 能够改变页面中的所有 CSS 样式
    • JavaScript 能够对页面中的所有事件做出反应

    1.查找 HTML 元素

    通常,通过 JavaScript,您需要操作 HTML 元素。

    为了做到这件事情,您必须首先找到该元素。有三种方法来做这件事:

    • 通过 id 找到 HTML 元素
    • 通过标签名找到 HTML 元素
    • 通过类名找到 HTML 元素

    1)通过 id 查找 HTML 元素

    在 DOM 中查找 HTML 元素的最简单的方法,是通过使用元素的 id。

    本例查找 id="intro" 元素:

    1 <script>
    2 x=document.getElementById("intro");
    3 document.write('<p>id="intro" 的段落中的文本是:' + x.innerHTML + '</p>');
    4 </script>

    结果:id="intro" 的段落中的文本是:Hello World!

    如果找到该元素,则该方法将以对象(在 x 中)的形式返回该元素。

    如果未找到该元素,则 x 将包含 null。

    2)通过标签名查找 HTML 元素

    实例

    本例查找 id="main" 的元素,然后查找 "main" 中的所有 <p> 元素:

    1 var x=document.getElementById("main");
    2 var y=x.getElementsByTagName("p");
    3 document.write('id 为 "main" 的 div 中的第一段文本是:' + y[0].innerHTML);

    2.JavaScript HTML DOM - 改变 HTML

    1)改变 HTML 输出流

    JavaScript 能够创建动态的 HTML 内容:

    今天的日期是: Thu Aug 15 2013 14:47:02 GMT+0800 (CST)

    在 JavaScript 中,document.write() 可用于直接向 HTML 输出流写内容。

    实例

    复制代码
     1 <!DOCTYPE html>
     2 <html>
     3 <body>
     4 
     5 <script>
     6 document.write(Date());
     7 </script>
     8 
     9 </body>
    10 </html>
    复制代码

    提示:绝不要使用在文档加载之后使用 document.write()。这会覆盖该文档。

    2)改变 HTML 内容

    修改 HTML 内容的最简单的方法是使用 innerHTML 属性。

    如需改变 HTML 元素的内容,请使用这个语法:

    document.getElementById(id).innerHTML=new HTML

    本例改变了 <h1> 元素的内容:

    复制代码
     1 <!DOCTYPE html>
     2 <html>
     3 <body>
     4 
     5 <h1 id="header">Old Header</h1>
     6 
     7 <script>
     8 var element=document.getElementById("header");
     9 element.innerHTML="New Header";
    10 </script>
    11 
    12 </body>
    13 </html>
    复制代码

    例子解释:

    • 上面的 HTML 文档含有 id="header" 的 <h1> 元素
    • 我们使用 HTML DOM 来获得 id="header" 的元素
    • JavaScript 更改此元素的内容 (innerHTML)

    3)改变 HTML 属性

    如需改变 HTML 元素的属性,请使用这个语法:

    document.getElementById(id).attribute=new value

    本例改变了 <img> 元素的 src 属性:

    复制代码
     1 <!DOCTYPE html>
     2 <html>
     3 <body>
     4 
     5 <img id="image" src="smiley.gif">
     6 
     7 <script>
     8 document.getElementById("image").src="landscape.jpg";
     9 </script>
    10 
    11 </body>
    12 </html>
    复制代码

    例子解释:

    • 上面的 HTML 文档含有 id="image" 的 <img> 元素
    • 我们使用 HTML DOM 来获得 id="image" 的元素
    • JavaScript 更改此元素的属性(把 "smiley.gif" 改为 "landscape.jpg"

    3.JavaScript HTML DOM - 改变 CSS

    1)改变 HTML 样式

    如需改变 HTML 元素的样式,请使用这个语法:

    document.getElementById(id).style.property=new style

    例子 

    本例改变了 id="id1" 的 HTML 元素的样式,当用户点击按钮时:

    1 <h1 id="id1">My Heading 1</h1>
    2 
    3 <button type="button" onclick="document.getElementById('id1').style.color='red'">
    4 点击这里
    5 </button>

    2)HTML DOM Style 对象参考手册  http://www.w3school.com.cn/htmldom/dom_obj_style.asp

    4.JavaScript HTML DOM - 事件

    1)对事件做出反应

    我们可以在事件发生时执行 JavaScript,比如当用户在 HTML 元素上点击时。

    如需在用户点击某个元素时执行代码,请向一个 HTML 事件属性添加 JavaScript 代码:

    onclick=JavaScript

    HTML 事件的例子:

    • 当用户点击鼠标时
    • 当网页已加载时
    • 当图像已加载时
    • 当鼠标移动到元素上时
    • 当输入字段被改变时
    • 当提交 HTML 表单时
    • 当用户触发按键时

    例子 1

    在本例中,当用户在 <h1> 元素上点击时,会改变其内容:

    <h1 onclick="this.innerHTML='谢谢!'">请点击该文本</h1>

    例子 2

    本例从事件处理器调用一个函数:

    复制代码
     1 <!DOCTYPE html>
     2 <html>
     3 <head>
     4 <script>
     5 function changetext(id)
     6 {
     7 id.innerHTML="谢谢!";
     8 }
     9 </script>
    10 </head>
    11 <body>
    12 <h1 onclick="changetext(this)">请点击该文本</h1>
    13 </body>
    14 </html>
    复制代码

    2)HTML 事件属性

    如需向 HTML 元素分配 事件,您可以使用事件属性。

    向 button 元素分配 onclick 事件:

    <button onclick="displayDate()">点击这里</button>

    点击按钮就可以执行 displayDate() 函数。 

    3) 使用 HTML DOM 来分配事件

    HTML DOM 允许您通过使用 JavaScript 来向 HTML 元素分配事件:

    实例

    向 button 元素分配 onclick 事件:

    1 <script>
    2 document.getElementById("myBtn").onclick=function(){displayDate()};
    3 </script>

    在上面的例子中,名为 displayDate 的函数被分配给 id=myButn" 的 HTML 元素。 

    4)onload 和 onunload 事件

    onload 和 onunload 事件会在用户进入或离开页面时被触发。

    onload 事件可用于检测访问者的浏览器类型和浏览器版本,并基于这些信息来加载网页的正确版本。

    onload 和 onunload 事件可用于处理 cookie。

    <body onload="checkCookies()">

    实例:

      

    复制代码
     1 <!DOCTYPE html>
     2   <html>
     3   <body onload="checkCookies()">
     4 
     5   <script>
     6   function checkCookies()
     7   {
     8   if (navigator.cookieEnabled==true)
     9   {
    10   alert("已启用 cookie")
    11   }
    12   else
    13   {
    14   alert("未启用 cookie")
    15   }
    16   }
    17   </script>
    18 
    19   <p>提示框会告诉你,浏览器是否已启用 cookie。</p>
    20   </body>
    21   </html>
    复制代码

    5)onchange 事件

    onchange 事件常结合对输入字段的验证来使用。

    下面是一个如何使用 onchange 的例子。当用户改变输入字段的内容时,会调用 upperCase() 函数。

    <input type="text" id="fname" onchange="upperCase()">

    实例:

      

    复制代码
     1 <!DOCTYPE html>
     2   <html>
     3   <head>
     4   <script>
     5   function myFunction()
     6   {
     7   var x=document.getElementById("fname");
     8   x.value=x.value.toUpperCase();
     9   }
    10   </script>
    11   </head>
    12   <body>
    13 
    14   请输入英文字符:<input type="text" id="fname" onchange="myFunction()">
    15   <p>当您离开输入字段时,会触发将输入文本转换为大写的函数。</p>
    16 
    17   </body>
    18   </html>
    19 
    20 6)onmouseover 和 onmouseout 事件
    21 
    22 onmouseover 和 onmouseout 事件可用于在用户的鼠标移至 HTML 元素上方或移出元素时触发函数。
    23 
    24 实例:
    25 
    26   <!DOCTYPE html>
    27   <html>
    28   <body>
    29 
    30   <div onmouseover="mOver(this)" onmouseout="mOut(this)" style="background-  color:green;120px;height:20px;padding:40px;color:#ffffff;">把鼠标移到上面</div>
    31 
    32   <script>
    33   function mOver(obj)
    34   {
    35   obj.innerHTML="谢谢"
    36   }
    37 
    38   function mOut(obj)
    39   {
    40   obj.innerHTML="把鼠标移到上面"
    41   }
    42   </script>
    43 
    44   </body>
    45   </html>
    复制代码

    7)onmousedown、onmouseup 以及 onclick 事件

    onmousedown, onmouseup 以及 onclick 构成了鼠标点击事件的所有部分。首先当点击鼠标按钮时,会触发 onmousedown 事件,当释放鼠标按钮时,会触发 onmouseup 事件,最后,当完成鼠标点击时,会触发 onclick 事件。

    三、JavaScript HTML DOM 元素(节点)

    1.创建新的 HTML 元素

    如需向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一个已存在的元素追加该元素。

    实例

    复制代码
     1 <div id="div1">
     2 <p id="p1">这是一个段落</p>
     3 <p id="p2">这是另一个段落</p>
     4 </div>
     5 
     6 <script>
     7 var para=document.createElement("p");
     8 var node=document.createTextNode("这是新段落。");
     9 para.appendChild(node);
    10 
    11 var element=document.getElementById("div1");
    12 element.appendChild(para);
    13 </script>
    复制代码

    例子解释:

    这段代码创建新的 <p> 元素:

    var para=document.createElement("p");

    如需向 <p> 元素添加文本,您必须首先创建文本节点。这段代码创建了一个文本节点:

    var node=document.createTextNode("这是新段落。");

    然后您必须向 <p> 元素追加这个文本节点:

    para.appendChild(node);

    最后您必须向一个已有的元素追加这个新元素。

    这段代码找到一个已有的元素:

    var element=document.getElementById("div1");

    这段代码向这个已有的元素追加新元素:

    element.appendChild(para);

    2.删除已有的 HTML 元素

    如需删除 HTML 元素,您必须首先获得该元素的父元素:

    实例

    复制代码
     1 <div id="div1">
     2 <p id="p1">这是一个段落。</p>
     3 <p id="p2">这是另一个段落。</p>
     4 </div>
     5 
     6 <script>
     7 var parent=document.getElementById("div1");
     8 var child=document.getElementById("p1");
     9 parent.removeChild(child);
    10 </script>
    复制代码

    例子解释:

    这个 HTML 文档含有拥有两个子节点(两个 <p> 元素)的 <div> 元素:

    <div id="div1">
    <p id="p1">这是一个段落。</p>
    <p id="p2">这是另一个段落。</p>
    </div>
    

    找到 id="div1" 的元素:

    var parent=document.getElementById("div1");

    找到 id="p1" 的 <p> 元素:

    var child=document.getElementById("p1");

    从父元素中删除子元素:

    parent.removeChild(child);

    提示:如果能够在不引用父元素的情况下删除某个元素,就太好了。

    不过很遗憾。DOM 需要清楚您需要删除的元素,以及它的父元素。

    这是常用的解决方案:找到您希望删除的子元素,然后使用其 parentNode 属性来找到父元素:

    var child=document.getElementById("p1");
    child.parentNode.removeChild(child);
     运行结果:这是另一个段落。

    四、JavaScript Window - 浏览器对象模型

    1.Window 对象

    所有浏览器都支持 window 对象。它表示浏览器窗口。

    所有 JavaScript 全局对象、函数以及变量均自动成为 window 对象的成员。

    全局变量是 window 对象的属性。

    全局函数是 window 对象的方法。

    甚至 HTML DOM 的 document 也是 window 对象的属性之一:

    window.document.getElementById("header");

    与此相同:

    document.getElementById("header");

    1)Window 尺寸

    有三种方法能够确定浏览器窗口的尺寸(浏览器的视口,不包括工具栏和滚动条)。

    对于Internet Explorer、Chrome、Firefox、Opera 以及 Safari:

    • window.innerHeight - 浏览器窗口的内部高度
    • window.innerWidth - 浏览器窗口的内部宽度

    对于 Internet Explorer 8、7、6、5:

    • document.documentElement.clientHeight
    • document.documentElement.clientWidth

    或者

    • document.body.clientHeight
    • document.body.clientWidth

    实用的 JavaScript 方案(涵盖所有浏览器):

    实例

    复制代码
    1 var w=window.innerWidth
    2 || document.documentElement.clientWidth
    3 || document.body.clientWidth;
    4 
    5 var h=window.innerHeight
    6 || document.documentElement.clientHeight
    7 || document.body.clientHeight;
    复制代码

    2)其他 Window 方法

    一些其他方法:

    • window.open() - 打开新窗口
    • window.close() - 关闭当前窗口
    • window.moveTo() - 移动当前窗口
    • window.resizeTo() - 调整当前窗口的尺寸

    2.JavaScript Window Screen

    window.screen 对象在编写时可以不使用 window 这个前缀。

    一些属性:

    • screen.availWidth - 可用的屏幕宽度
    • screen.availHeight - 可用的屏幕高度

    1)Window Screen 可用高度

    screen.availHeight 属性返回访问者屏幕的高度,以像素计,减去界面特性,比如窗口任务栏。

    实例

    返回您的屏幕的可用高度:

    <script>
    document.write("可用高度:" + screen.availHeight);
    </script>

    以上代码输出为:可用高度:1058

  • 相关阅读:
    block的使用
    控制器的多种创建方式
    指针函数和函数指针
    UIScrollView实现图片轮播器及其无限循环效果
    如何按顺序执行两个动画
    代理、通知、KVO的应用
    CAlayer层的属性
    UIView的autoresizingMask和autoresizesSubviews属性的剖析
    面向对象编程思想(OOP)总结
    scala中闭包的使用
  • 原文地址:https://www.cnblogs.com/binzhihua-666/p/6007813.html
Copyright © 2011-2022 走看看