全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解js的事件处理函数和动态创建html标记方法

1 HTML的事件属性

全局事件属性:HTML 4 增加了使事件在浏览器中触发动作的能力,比如当用户点击元素时启动 JavaScript。

  a. Window 事件属性,针对 window 对象触发的事件(应用到 <body> 标签),常用的为onload。

  b. Form事件,由 HTML 表单内的动作触发的事件(应用到几乎所有 HTML 元素,但最常用在 form 元素中):常用的为onblur、onfocus、onselect、onsubmit。

  c. keybord事件

  d.Mouse事件,由鼠标或类似用户动作触发的事件:常用的为onclick、onmouseover、onmouseout。

  e. Media事件,由媒介(比如视频、图像和音频)触发的事件(适用于所有 HTML 元素,但常见于媒介元素中,比如 <audio>、<embed>、<img>、<object> 以及     <video>)。

2  事件处理函数

文档的结构与文档的行为混杂在一起,例如:

<a href="images/example.jpg" onclick="showPic(this);return false;">

文档的结构与文档的行为分开,例如:

element.onclick = function() { showPic(whichpic); return false; }

3 共享onload事件

页面加载之后立即执行一段 JavaScript:<element onload="script">,如果想让页面加载后执行多个脚本呢?办法是:

window.onload = function() {
 script1;
 script2;
 script3;
 ......
 }

但是这个办法没有弹性,如果需要加载的脚本不断变化,那么代码也要跟着变化,更好的办法是:

 function addLoadEvent(func)() {
 var oldonload = window.onload;
 if (typeof window.onload !="function") {
  window.onload = func;
 } else {
  window.onload = function() {
   oldonload();
   func;
  }
 }
 }

4 动态创建html标记

  a. 两个传统的方法

    document.write方法和innerHTML属性,两者都不是标准化的DOM(W3C标准)所支持的方法和属性,它们都是html的专有属性。

    document.write方法可以很方便的插入元素标签,尤其是字符串。但是它与网页设计应将行为(脚本)和结构(html标签)分离的原则相背。

<!DOCTYPE html>
 <html>
 <head>
 <meta chaset="utf-8" />
 <title>document.write</title>
 <body>
  <script>
  <!--可以很方便的插入元素标签,尤其是字符串.但是它与网页设计应将行为(脚本)和结构(html标签)分离的原则-->
  document.write("<p>This is inserted by document.write</p>");
  </script>
 </body>
 </head>
 </html>

innerHTML适合将一大段HTML内容插入网页,如:

<div id="testdiv">
 </div>
 window.onload = function() {
 var testdiv = document.getElementById("testdiv");
 testdiv.innerHTML = "<p>This is inserted by <em>innerHTML</em></p><en>";
 }

  b. 更加精细化的dom方法-获取dom节点树和改变dom节点树

    检索节点(元素):document.getElementById和element.getElementsByTagName
   
    创建节点(元素):document.createElement,document.createTextNode
   
    追加节点(元素):element.appendChild

    插入(将一个节点插入到另一个节点之前):parentEelement.insertBefore(newElement, targetElement)

    很有用的属性:element.parentNode(获取父节点)、element.nextSibling(获取兄弟节点)

    上面用innerHTML属性插入HTML的效果用dom方法照样可以实现:

 window.onload = function() {
  var testdiv = document.getElementById("testdiv");
  var para = document.createElement("p");
  testdiv.appendChild(para);
  var context1 = doument.createTextNode("This is inserted by ");
  para.appendChild(context1);
  var emphasis = document.createElement("em");
  para.appendChild(emphasis);
  var context2 = document.createTextNode("method of domcore");
  emphasis.appendChild(context2);
 }

利用上面的dom方法写一个将一个节点插入到另一个节点之后的函数:

function insertAfter(newElement, targetElement) {
 var parent = targetElement.parentNode;
 if (parent.lastChild == targetElement) {
  parent.appendChild(newElement);
 } else {
  targetElement.inserBefore(newElement, targetElement.nextSibling);
 }
}

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# js  # 事件处理函数  # 创建html  # 为radio类型的INPUT添加客户端脚本(附加实现JS来禁用onClick事件思路代码)  # 怎么通过onclick事件获取js函数返回值(代码少)  # javascript 动态改变onclick事件触发函数代码  # JavaScript利用发布订阅模式编写事件监听函数  # ES6中javascript实现函数绑定及类的事件绑定功能详解  # JavaScript触发onScroll事件的函数节流详解  # 深入理解Node.js 事件循环和回调函数  # 实例讲解javascript注册事件处理函数  # js动态添加input按钮并给按钮增加onclick的函数事件(带参数)完整实例  # 文档  # 尤其是  # 加载  # 网页设计  # 很方便  # 它与  # 应将  # 都是  # 鼠标  # 多个  # 也要  # 适用于  # 可以实现  # 想让  # 几乎所有  # 用在  # 表单  # 很有用  # 最常  # 大段 


相关文章: 高端企业智能建站程序:SEO优化与响应式模板定制开发  建站之星如何快速解决建站难题?  网站企业制作流程,用什么语言做企业网站比较好?  ,有什么在线背英语单词效率比较高的网站?  ,石家庄四十八中学官网?  详解jQuery停止动画——stop()方法的使用  官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  建站之星如何开启自定义404页面避免用户流失?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  已有域名能否直接搭建网站?  安徽网站建设与外贸建站服务专业定制方案  定制建站是什么?如何实现个性化需求?  php json中文编码为null的解决办法  如何选择高效可靠的多用户建站源码资源?  建站之星安装后如何配置SEO及设计样式?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  公司网站的制作公司,企业网站制作基本流程有哪些?  如何在宝塔面板中创建新站点?  b2c电商网站制作流程,b2c水平综合的电商平台?  C++时间戳转换成日期时间的步骤和示例代码  已有域名和空间如何快速搭建网站?  详解jQuery中基本的动画方法  如何在腾讯云服务器上快速搭建个人网站?  购物网站制作公司有哪些,哪个购物网站比较好?  建站之星如何实现PC+手机+微信网站五合一建站?  淘宝制作网站有哪些,淘宝网官网主页?  如何选择香港主机高效搭建外贸独立站?  如何基于云服务器快速搭建网站及云盘系统?  已有域名如何快速搭建专属网站?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  兔展官网 在线制作,怎样制作微信请帖?  如何高效利用亚马逊云主机搭建企业网站?  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  七夕网站制作视频,七夕大促活动怎么报名?  如何选择高效稳定的ISP建站解决方案?  php8.4新语法match怎么用_php8.4match表达式替代switch【方法】  建站三合一如何选?哪家性价比更高?  建站之家VIP精选网站模板与SEO优化教程整合指南  制作网站的软件免费下载,免费制作app哪个平台好?  成都网站制作报价公司,成都工业用气开户费用?  Android使用GridView实现日历的简单功能  建站之星图片链接生成指南:自助建站与智能设计教程  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何确认建站备案号应放置的具体位置?  北京营销型网站制作公司,可以用python做一个营销推广网站吗?  红河网站制作公司,红河事业单位身份证如何上传?  网页设计与网站制作内容,怎样注册网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。