js中script的上下放置区别,Dom的增删改创建操作实例分析


Posted in Javascript onDecember 16, 2019

本文实例讲述了js中script的上下放置区别,Dom的增删改创建操作。分享给大家供大家参考,具体如下:

回顾

javascript分为三部分:

1、ECMAScript5.0 es6(阮一峰) es7 es8    es6中有类的概念

声明变量 var  let(es6中语法)
内置函数 Date Math.random

if else  switch while do-while  for

2、DOM  Document Object Model

获取DOM事件的三种方式

  • getElementById()
  • getElementsByTagName()
  • getElementsByClassName()

DOM的三步走

  • ①、事件对象
  • ②、事件、
  • ③、事件驱动

值操作: <div></div> too liang
oDiv.innerText='too liang';仅仅设置文本
oDiv.innerHTML='<h2>too liang</h2>';文本和标签一起渲染
oInput.value='alex';仅仅是对表单控件有效

标签属性操作;

设置类名:oDiv.className+=' active';追加类名、
设置id:oDiv.id='box';

样式操作:

oDiv.style.(css中所有的样式属性)

注意驼峰体:如果margin-left 使用js的时候marginLeft

3、BOM

<script></script>在head和body中放置的区别

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <script>
    //加载顺序:1DOM元素加载 2图片加载
    //1等待DOM和图片资源加载完成之后才调用window.onload后面的方法
    //2事件覆盖事件,也即同时存在多个window.noload时,后面的覆盖前面的
    window.onload=function () {
      // var oBtn=document.getElementById('btn');
      // console.log(oBtn);
      function $(idName){
        return document.getElementById(idName);
      }
      $('btn').onclick=function(){



。。。。。。
      };
    }
  </script> <!--没有操作DOM时可以将script放在这里面,如果要使用DOM的相关操作,使用window.onload,建议最好写在body里面-->
</head>

DOM的增删改查

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
</head>
<body>
<button id="btn">追加</button>
<button id="del">删除</button>
<div id="box">
  <p>测试段落</p>
</div>
  <script>
    //加载顺序:1DOM元素加载 2图片加载
    //1等待DOM和图片资源加载完成之后才调用window.onload后面的方法
    //2事件覆盖现在,同时存在多个window.noload时,后面的覆盖前面的
    window.onload=function () {
      // var oBtn=document.getElementById('btn');
      // console.log(oBtn);
      function $(idName){
        return document.getElementById(idName);
      }
      $('btn').onclick=function(){
        //1DOM的创建
        var oP=document.createElement('p');
        //2 DOM的追加
        $('box').appendChild(oP);
        //3 DOM的修改
        oP.innerText='alex';
        oP.id='p1';//设置id
        var oA=document.createElement('abc');//自定义创建
        oA.innerText='321';
        oA.id='abc';
        $('box').insertBefore(oA,oP);//在oA之前插入
      };
      //4 DOM的删除操作
      $('del').onclick=function(){
        $('box').removeChild($('p1'));
        $('box').removeChild($('abc'));
      }
    }
  </script>
</body>
</html>

应用场景分析

如果是一开始页面有初始化渲染开销;应用:频繁的切换:display:none|block  或者 追加className 删除className

如果是DOM的创建和删除 如果你是频繁的切换,对DOM的性能消耗很大,所以最好应用在少量的切换上面

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
js 页面输出值
Nov 30 Javascript
Javascript Math ceil()、floor()、round()三个函数的区别
Mar 09 Javascript
瀑布流布局并自动加载实现代码
Mar 12 Javascript
ie下$.getJSON出现问题的解决方法
Feb 12 Javascript
jQuery中clearQueue()方法用法实例
Dec 29 Javascript
深入讲解AngularJS中的自定义指令的使用
Jun 18 Javascript
jquery实现点击其他区域时隐藏下拉div和遮罩层的方法
Dec 23 Javascript
详解JavaScript中|单竖杠运算符的使用方法
May 23 Javascript
详解使用vuex进行菜单管理
Dec 21 Javascript
JS实现数组去重,显示重复元素及个数的方法示例
Jan 21 Javascript
vue踩坑记录之数组定义和赋值问题
Mar 20 Javascript
微信小程序点击保存图片到本机功能
Dec 13 Javascript
JavaScript 浏览器对象模型BOM原理与常见用法实例分析
Dec 16 #Javascript
javascript自定义右键菜单插件
Dec 16 #Javascript
js中的面向对象之对象常见创建方法详解
Dec 16 #Javascript
js实现数字滚动特效
Dec 16 #Javascript
NUXT SSR初级入门笔记(小结)
Dec 16 #Javascript
js实现内置计时器
Dec 16 #Javascript
js实现秒表计时器
Dec 16 #Javascript
You might like
Yii隐藏URL中index.php的方法
2016/07/12 PHP
php实现将二维关联数组转换成字符串的方法详解
2017/07/31 PHP
PHP开发者必须掌握的6个关键字
2014/04/14 Javascript
使用typeof判断function是否存在于上下文
2014/08/14 Javascript
JavaScript随机生成信用卡卡号的方法
2015/04/07 Javascript
Angular 路由route实例代码
2016/07/12 Javascript
JavaScript函数基础详解
2017/02/03 Javascript
node安装--linux下的快速安装教程
2017/03/21 Javascript
Vue.js手风琴菜单组件开发实例
2017/05/16 Javascript
微信小程序对接七牛云存储的方法
2017/07/30 Javascript
使用DataTable插件实现异步加载数据
2017/11/19 Javascript
JS实现读取xml内容并输出到div中的方法示例
2018/04/19 Javascript
解决Vue2.0 watch对象属性变化监听不到的问题
2018/09/11 Javascript
详解一个基于套接字实现长连接的express
2019/03/28 Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
2019/06/14 Javascript
最简单的vue消息提示全局组件的方法
2019/06/16 Javascript
微信小程序HTTP接口请求封装代码实例
2019/09/05 Javascript
jQuery实现鼠标移入显示蒙版效果
2020/01/11 jQuery
JavaScript实现音乐导航效果
2020/11/19 Javascript
python虚拟环境virualenv的安装与使用
2016/12/18 Python
python3.6.3转化为win-exe文件发布的方法
2018/10/31 Python
Python小进度条显示代码
2019/03/05 Python
Django Sitemap 站点地图的实现方法
2019/04/29 Python
Python简单处理坐标排序问题示例
2019/07/11 Python
详解Python3 pickle模块用法
2019/09/16 Python
自定义实现 PyQt5 下拉复选框 ComboCheckBox的完整代码
2020/03/30 Python
如何在sublime编辑器中安装python
2020/05/20 Python
python 基于卡方值分箱算法的实现示例
2020/07/17 Python
Python jieba库分词模式实例用法
2021/01/13 Python
英国折扣零售连锁店:QD Stores
2018/12/08 全球购物
干部行政关系介绍信
2014/01/17 职场文书
2014年保卫部工作总结
2014/11/21 职场文书
2015年安全生产责任书
2015/01/30 职场文书
通知范文怎么写
2015/04/16 职场文书
MySQL索引知识的一些小妙招总结
2021/05/10 MySQL
详解Go语言Slice作为函数参数的使用
2021/07/02 Golang