要想和浏览器有交互的动作,即要继续学习DOM,BOM。

JavaScript分为 ECMAScript,DOM,BOM。

BOM (Browser Object Model) 是指浏览器对象模型,他使js有能力和浏览器进行交互;

DOM (Document Object Model)是指文档对象模型,通过它,可以访问HTML 文档的所有元素;

在BOM里:

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

window.location 对象用于获得当前页面的地址 (URL),并把浏览器重定向到新的页面。

1. location
  1. location.href --> 获取当前的URL
  2. location.href="http://www.luffycity.com" --> 跳转到指定网址
  3. location.reload() --> 重新加载当前页面

2. setTimeout和clearTimeout
  多少毫秒之后做什么事儿,注意事情只会执行一次; 

var t=setTimeout("JS语句 或者是 函数名",毫秒)

3. setInterval和clearInterval
  每隔多少毫秒之后做什么事儿,可以用作定时器

ar timer = setTimeout(function(){alert(123);}, 3000)
// 取消setTimeout设置
clearTimeout(timer);

 定时器的列子:

<script>
var timer;
<!--在js文件里面报错了,因为要让文档树执行完后,才能得到标签-->
function f() {
var now = new Date();
var nowStr = now.toLocaleString();
// consle.log(nowStr);
//找到输入框
var inEle = document.getElementById("t1");
inEle.value = nowStr;
}
// 点开始按钮的时候就开始出现时间(触发事件),每隔一秒就执行一次 var startEle = document.getElementById("i1");
startEle.onclick = function () {
f();
//setInterval(函数名,毫秒数)
//当多次点击开始,则会生成多个定时器,但是清除只能清除最后一个。
if (timer === undefined){
//setInterval(函数名,毫秒数)
timer = setInterval(f,1000);
}
}; var stopEle = document.getElementById("i2");
stopEle.onclick = function () {
//清除定时器的时候出现了问题,因为定时器在另外一个函数内部,为局部变量。要设为全局的变量,才能共同的使用
clearTimeout(timer);
//清除只是清除那个定时器,但是定时器的值还是存在的,
timer = undefined;
// console.log(timer)
};
</script>  

4.弹出框

1.警告框:

alert("你看到了吗?");  

在DOM里

当网页被加载完成后,浏览器会创建页面的文档对象模型;

这个模型也被称为文档树;

文档树的图形:

DOM标准规定HTML文档中的每个成分都是一个节点(node):

  • 文档节点(document对象):代表整个文档
  • 元素节点(element 对象):代表一个元素(标签)
  • 文本节点(text对象):代表元素(标签)中的文本
  • 属性节点(attribute对象):代表一个属性,元素(标签)才有属性
  • 注释是注释节点(comment对象) 

JavaScript 可以通过DOM创建动态的 HTML:

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

对DOM的操作:

1.查找标签:

  1.基本查找:

    1. 根据ID找标签(有且只能找到一个)
      document.getElementById("ID值")
    2. 根据class名字找(找到的可以是多个)
      document.getElementsByClassName("class值")
    3. 根据标签名找(找到的可以是多个)
      document.getElementsByTagName("标签名")

  2.间接的查找:

    1. 找父标签
      document.parentElement
    2. 找子标签(找到的可能是多个)
      document.children
    3. 第一个子标签
      document.firstElementChild
    4. 最后一个子标签
      document.lastElementChild

    兄弟标签是在同一级上寻找的

    5. 上一个兄弟标签
      document.previousElementSibling

    6. 下一个兄弟标签

      document.nextElementSibling

2.创建标签

 非常重要:

var divEle = document.createElement("div");

3. 添加节点
  1. 在someone内部的 最后 添加
    someone.appendChild("标签名")
  2. 在someone内部的某个标签的前面插入
    someone.insertBefore(要插入的新标签, 哪个标签之前)

4.删除节点:

  somenode.removeChild(要删除的节点)  

5.属性的节点:

  1.获取文本节点的值:  

var divEle = document.getElementById("d1")
divEle.innerText // 获得 文本 的值
divEle.innerHTML  //获得 文本的值和标签(也就是所有的内容)
var divEle = document.getElementById("d1")
divEle.innerText="1"
divEle.innerHTML="<p>2</p>"

  attribute 操作: 

    自带的属性通过
      .属性名="属性值"
      imgElem.src="..."
    自定义的属性只能用:
      .setAttribute("s9", "hao") 给属性设置值
      .getAttribute("s9") 获取属性值
      .removeAttribute("s9") 删除属性

6. 样式操作 

  1.通过class进行修改

className  获取所有样式类名(字符串)

classList.remove(cls)  删除指定类
classList.add(cls) 添加类
classList.contains(cls) 存在返回true,否则返回false
classList.toggle(cls) 存在就删除,否则添加 

  2. 通过.style修改
    1. 有中横线的(background-color),将中横线后面的第一个字母换成大写即可,即驼峰式
      obj.style.backgroundColor
    2. 没有中横线的
      obj.style.color

 

7.事件

常用的事件

onclick        当用户点击某个对象时调用的事件句柄。
ondblclick 当用户双击某个对象时调用的事件句柄。 onfocus 元素获得焦点。 // 练习:输入框
onblur 元素失去焦点。 应用场景:用于表单验证,用户离开某个输入框时,代表已经输入完了,我们可以对它进行验证.
onchange 域的内容被改变。 应用场景:通常用于表单元素,当元素内容被改变时触发.(select联动) //上面几个事件是重要的 onkeydown 某个键盘按键被按下。 应用场景: 当用户在最后一个输入框按下回车按键时,表单提交.
onkeypress 某个键盘按键被按下并松开。
onkeyup 某个键盘按键被松开。
onload 一张页面或一幅图像完成加载。
onmousedown 鼠标按钮被按下。
onmousemove 鼠标被移动。
onmouseout 鼠标从某元素移开。
onmouseover 鼠标移到某元素之上。 onselect 在文本框中的文本被选中时发生。
onsubmit 确认按钮被点击,使用的对象是form。

2. 绑定事件的方式
  1. 在标签里直接写属性(onclick=foo())

<div id="d1" onclick="changeColor(this);">点我</div>
<script>
function changeColor(ths) {
ths.style.backgroundColor="green";
}
</script>

  2. 通过JS给标签绑定事件

  3. this --> 代表的是 触发事件的当前标签  

  

<script>
var inEle = document.getElementById("t1");
var vauEle = inEle.value;
//点击文本框的时候
inEle.onfocus = function () {
this.value =""
};
//远离文本框的时候
inEle.onblur = function () {
this.value = vauEle;
}
</script>

  

  

前端——BOM和DOM的更多相关文章

  1. 前端——BOM与DOM

    目录 前戏 window对象 window的子对象 navigator对象(了解即可) screen对象(了解即可) history对象(了解即可) location对象 弹出框 计时相关 DOM H ...

  2. Web前端 --- BOM和DOM

    目录 前端基础之BOM和DOM BOM DOM 前端基础之BOM和DOM BOM是指浏览器对象模型,他使JavaScript有能力与浏览器进行对话 DOM是指文档对象模型,通过它,可以访问HTML文档 ...

  3. 前端BOM和DOM

      前端基础之BOM和DOM   前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些 ...

  4. 前端 -- BOM和DOM

    一,引入 到目前为止,已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互,我们需要继续学习BOM和DO ...

  5. 前端基础之DOM和BOM

    前端基础之DOM和BOM JavaScript分为 ECMAScript,DOM,BOM. BOM(Browser Object Model)是指浏览器对象模型,它使 JavaScript 有能力与浏 ...

  6. JS BOM DOM对象 select联动 计时器 时间 css操作 节点(标签 ) 查找标签 {前端基础之BOM和DOM}

    前端基础之BOM和DOM 前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互,我 ...

  7. 前端基础之BOM和DOM day52

    前端基础之BOM和DOM   前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交互 ...

  8. 前端(4)BOM与DOM

    前端(4)BOM与DOM I/O前戏 到目前为止,我们已经学过了JavaScript的一些简单的语法.但是这些简单的语法,并没有和浏览器有任何交互. 也就是我们还不能制作一些我们经常看到的网页的一些交 ...

  9. 第四章、前端之BOM和DOM

    目录 第四章.前端之BOM和DOM 一.解释BOM和DOM 二.window对象 三.window子对象 四.弹出框 五.计时相关 六.HTML的DOM树 七.查找元素 八.节点操作 九.JS操作CS ...

随机推荐

  1. 2019春第十周作业Compile Summarize

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 在这里 我在这个课程的目标是 能够对C语言的编写更加得心应手 这个作业在那个具体方面帮助我实现目标 结构体更进一步 参考文献与网址 C语言 ...

  2. 代码块: 以冒号作为开始,用缩进来划分作用域,这个整体叫做代码块,python的代码块可以提升整体的整齐度,提高开发效率

    # ### 代码块: 以冒号作为开始,用缩进来划分作用域,这个整体叫做代码块 if 5 == 5: print(1) print(2) if True: print(3) print(4) if Fa ...

  3. 【Idea】Intellij Idea debug 模式如果发现异常,即添加异常断点在发生异常处

    前用eclipse的时候,可以根据所抛出的异常进行调试,比如:出现了空指针异常,我想知道是哪一行抛出的,在eclipse中我只需在debug模式下把空指针异常这个名字设置进去,当遇到空指针异常时,ec ...

  4. 两种库解析、构造 JSON

    1.用CJSON库 1.1解析Json 需要解析的JSON文件: { "name":"Tsybius", , "sex_is_male":t ...

  5. Oracle 12C 补丁升级

    升级步骤 Oracle 12.2.0.1升级至12.2.0.1.190115 1.阅读readme文件 2.检查更新opatch 3.备份程序 4.使用opatchauto工具进行数据库升级 5.打O ...

  6. 安装linux虚拟机

    虚拟机安装流程 1. 安装系统 安装完成 2. 安装VMware tools linux(ubuntu 18.04 Desktop) 手动安装 1) 加载光驱 2) 双击进入光驱,在光驱的目录下,打开 ...

  7. 福州大学软件工程1916|W班 第5次作业成绩排名

    1. 作业链接: https://edu.cnblogs.com/campus/fzu/SoftwareEngineering1916W/homework/2768 2. 评分准则: 本次作业评分分为 ...

  8. To My Girlfriend (DP)

    题意:求选中若干个数,满足和为S,且不能选中下表i, j 和选中k, l的情况总数量. 思路:DP[i][j][k][l] i:前i个和为j,选中k个和不选中l个的情况数量,那么我们的转换应该是在必选 ...

  9. Oracle树查询及相关函数

    Oracle树查询的最重要的就是select...start with... connect by ...prior 语法了.依托于该语法,我们可以将一个表形结构的中以树的顺序列出来.在下面列述了Or ...

  10. 转--Python re模块 验证11位手机号

      一.常用正则表达式符号和语法:   '.' 匹配所有字符串,除\n以外 ‘-’ 表示范围[0-9] '*' 匹配前面的子表达式零次或多次.要匹配 * 字符,请使用 \*. '+' 匹配前面的子表达 ...