很伤心,就在前天下午,本人的电脑突然挂了,电脑售后告知需要10个工作日才可修好.

  于是乎,昨天学的内容来不及整理,暂且跳过,改天再抽空补上,就当缓几天再复习吧.

  今天继续学习了JS的内容.

  

1 js的内置对象

1-1 Array对象

1. 定义
* Array对象是数组对象,跟java中的数组一个意思,但是使用语法上稍微有些区别。

2. 使用
a. 创建数组对象
* 创建一个空数组:var arr = new Array();
* 创建一个指定大小的数组:var arr = new Array(size);
* 创建数组并填充元素:var arr = new Array(element0, element1, ..., elementn);
* 直接创建元素数组:var arr = [element0, element1, ..., elementn];

* 数组的特性:js没有集合,为了方便使用,数组可以自动扩容。

b.数组中的元素获取
* 跟java一样通过索引的方式获得数组中的元素:

c. 数组的常用属性:length
* 细节:不存在数组越界的问题

d. 获得数组中的一个元素:arr[0]
遍历获得数组中的所有元素:
for(var i=0;i<arr.length;i++){
alert(arr[i]);
}

3. 多维数组的操作
a. js中的多维数组跟java中相似,也就是数组中的元素也是数组
arr = [ [1,2,3], [4,5,6],[7,8,9] ];

arr[1][0]

获取数组中的8数字可以:arr[2][1]

* 数组的成员,也是一个数组,就是多维数组.

1-2 String对象

1. 创建方式
var str1=new String("abc");
var str2="abc";

* 细节:需要开点脑洞
* str1是引用对象,指向一个字符串对象;str2是基本类型,指向一个字符串。
* typeof str1:返回结果是:object(引用类型); typeof str2:返回结果是:string(基本类型)
* 但是两者在使用上,没有任何区别。

2. 常见方法
* charAt(number):获取指定位置的字符
* indexOf():查找某个字符的第一次出现的下标
* lastIndexOf():查找某个字符最后一次出现的下标
* split():切割字符串
* substring(i,j):截取字符

1-3 Date日期对象

1. 创建方式
* 创建当前日期时间:var date = new Date();
* 创建指定日期时间:var date = new Date(毫秒值);
* 其中毫秒值为1970-01-01至今的时间毫秒值

2. 创建方法
* getFullYear() 从 Date 对象以四位数字返回年份。
* getMonth() 从 Date 对象返回月份 (0 ~ 11)。
* getDay() 从 Date 对象返回一周中的某一天 (0 ~ 6)。
* getDate() 从 Date 对象返回一个月中的某一天 (1 ~ 31)。
* getTime() 返回 1970 年 1 月 1 日至今的毫秒数。

1-4 Math对象

1. 介绍
* Math对象是数学对象,是一个工具对象
* Math对象不用使用new的方式创建,直接使用Math就可以调用对象内部的方法。

2. 常用方法
* abs(x) 返回数的绝对值。
* ceil(x) 对数进行上舍入。 3.1 -->4
* floor(x) 对数进行下舍入。 3.9 -->3
* random() 返回 0 ~ 1 之间的随机数。 [0,1): 前闭后开区间
* round(x) 把数四舍五入为最接近的整数。

2 DOM 

2-1 定义

1. 定义
* DOM(document object model),文档对象模型,DOM定义了操作HTML文档的接口,提供了访问HTML文档的途径和操作方法。

document.getElementById(); //dom的一个接口

2. 原理
* html文档加载到浏览器的内存中后,我们认为形成了一颗DOM树(浏览器内存中),即html标签按照层级结构而形成了一颗“家谱树”,而任何一个html标签、标签属性和文本都是这个树上的节点元素。

* 通过模型提供的接口,修改html文档的内容,即通过js动态的修改内存中的DOM树。

3. 演示dom树的创建

    <html>
<head>
<title>标题</title>
</head>
<body>
<h1>h1标题</h1>
<a href="http://www.baidu.com">百度</a>
</body>
</html>

2-2 标签的操作

2-3-1 获取元素节点

1. 方法
* getElementByid("id值"):根据id获取元素
<xxx id="id值"> ----整个html文档唯一

* getElementsByTagName("html标签名"):根据html标签获取多个元素
* <xxx> : xxx即标签名

* getElementsByClassName("class属性的名字"):根据类名获取多个元素
* <xxx class="class属性的名字">

* getElementsByName("name属性的名字"):根据name属性获取多个元素
* <xxx name="name的属性名字"> --整个html文档不唯一

2. 难点
* getElementsByTagName,getElementsByClassName,getElementsByName获取的是多个,返回的是一个html元素的数组,使用的时候,必须要遍历。

2-3-2 获取和设置文本节点

* innerHTML
* innerText

2-3-3 获取和设置属性节点

1. 方法
* getAttribute(属性的名字):获取属性的值
* setAttribute(属性的名字,属性的值):设置属性的值
* removeAttribute(name):删除某个属性

2. 对比以前的方式如何使用
* HTML元素,固有的属性,使用以前的获取和设置的方法;对于自定义属性,使用getAttribute,setAttribute

1. 方法
* getAttribute(属性的名字):获取属性的值
* setAttribute(属性的名字,属性的值):设置属性的值
* removeAttribute(name):删除某个属性

2. 对比以前的方式如何使用
* HTML元素,固有的属性,使用以前的获取和设置的方法;对于自定义属性,使用getAttribute,setAttribute

1. 方法
* 父节点.hasChildNodes():判断是否有子节点(细节:有看不见的子节点)
* firstChild: 属性,第一个子节点信息
* childNodes: 属性,返回所有节点

* 父节点.removeChild(子节点):删除子节点
* document.createElement(node):创建一个新元素
* 父节点.replaceChild(newnode, oldnode):替换子节点
* 父节点.appendChild(node):添加子节点
* 父节点.insertBefore(newnode,brothernode); // 在指定兄弟节点之前,插入新节点

2. 要点
* 先找“孩子他爸”,后操作“孩子”

3.难点
document.createElement("参数")的使用:
参数:你需要创建的html元素的标签名字

day04 JS的更多相关文章

  1. Day04 dom详解及js事件

    day04 dom详解 DOM的基础 Document对象 Element对象 Node对象 innerHTML 事件处理 表单验证   上次课内容回顾: JS中ECMAScript用法: JS定义变 ...

  2. js下 Day04、DOM操作--自定义属性

    语法: 元素.getAttribute('自定义属性名') 功能:获取自定义属性 语法: 元素.setAttribute('自定义属性名','值') 功能:设置自定义属性 语法: 元素.removeA ...

  3. Node.js 自学之旅

    学习基础,JQuery 原生JS有一定基础,有自己一定技术认知(ps:原型链依然迷糊中.闭包6不起来!哎!) 当然最好有语言基础,C#,java,PHP等等.. 最初学习这个东西的原因很简单,在园子里 ...

  4. Node.js 自学之旅(初稿篇)

    学习基础,JQuery 原生JS有一定基础,有自己一定技术认知(ps:原型链依然迷糊中.闭包6不起来!哎!) 当然最好有语言基础,C#,java,PHP等等.. 最初学习这个东西的原因很简单,在园子里 ...

  5. day04 orm操作

    day04 orm操作 昨日内容回顾 小白必会三板斧 request对象方法 静态文件 请求方式 python链接数据库 django链接数据库 小白必会三板斧 HttpResponse :返回前端浏 ...

  6. Vue.js 和 MVVM 小细节

    MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式,其核心是提供对View 和 ViewModel 的双向数据绑定,这使得ViewModel 的状态改变可以自 ...

  7. js学习笔记:操作iframe

    iframe可以说是比较老得话题了,而且网上也基本上在说少用iframe,其原因大致为:堵塞页面加载.安全问题.兼容性问题.搜索引擎抓取不到等等,不过相对于这些缺点,iframe的优点更牛,跨域请求. ...

  8. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  9. JS调用Android、Ios原生控件

    在上一篇博客中已经和大家聊了,关于JS与Android.Ios原生控件之间相互通信的详细代码实现,今天我们一起聊一下JS调用Android.Ios通信的相同点和不同点,以便帮助我们在进行混合式开发时, ...

随机推荐

  1. Python程序练习4--模拟员工信息数据库操作

    1.功能简介 此程序模拟员工信息数据库操作,按照语法输入指令即能实现员工信息的增.删.改.查功能.   2.实现方法 架构: 本程序采用python语言编写,关键在于指令的解析和执行:其中指令解析主要 ...

  2. NIO FileChannel

    NIO提供了比传统的文件访问更好的访问方法,NIO有两个优化的方法:一个是 FIleChannel.transferTo FileChannel.transferFrom,另一个是FileChanne ...

  3. 【ASP.NET MVC 学习笔记】- 16 Model Binding(模型绑定)

    本文参考:http://www.cnblogs.com/willick/p/3424188.html. 1.Model Binding是Http请求和Action方法之间的桥梁,是MVC框架根据Htt ...

  4. LeetCode 1. Two Sum (两数之和)

    Given an array of integers, return indices of the two numbers such that they add up to a specific ta ...

  5. 【计算机网络】 一个小白的网络层学习笔记:总结下IP,NAT和DHCP

    前言:这篇文章是学习网络层协议时候总结的笔记,前面的主要部分介绍的都是IP协议, 后半部分介绍NAT协议和DHCP协议 参考书籍 <计算机网络-自顶向下>       作者 James F ...

  6. Python实现网站注册验证码生成类

    # -*- coding:utf-8 -*- ''' Created on 2017年4月7日 @author: Water ''' import os import random import st ...

  7. Java基础笔记4

    数组 有一组相同数据类型的数据. 数据类型[] 数组名称=new 数据类型[长度]; //为该数组开辟空间. 数据类型[] 数组名称={值,值}; 求数组的长度 数组名称.length; 获取数组中的 ...

  8. Spring容器组建注解@Component和Resouces实现完全注解配置

    @Resource和@Component实现零XML配置 1.@Resource的注解: @Resource是J2EE的注解.意思是说在容器里面找相应的资源.也可以通过name属性指定它name的资源 ...

  9. C. New Year and Rating

    C. New Year and Rating time limit per test 2 seconds memory limit per test 256 megabytes input stand ...

  10. 2015-2016 ACM-ICPC, NEERC, Southern Subregional Contest I Lottery

    LotteryCrawling in process... Crawling failed Time Limit:2000MS     Memory Limit:524288KB     64bit ...