Title

js知识点

js知识点

js

js的核心
1 文档对象模型(DOM)
2 浏览器对象模型(BOM)

js优点
JavaScript 是脚本语言
JavaScript 是一种轻量级的编程语言。
JavaScript 是可插入 HTML 页面的编程代码。
JavaScript 插入 HTML 页面后,可由所有的现代浏览器执行。
JavaScript 很容易学习。

数据类型

1 js中不区分整型和浮点型,都叫数值类型
	1 整型
    2 浮点型
    3 NaN=====>not a number
var str = `my name is ${name}, my age is ${age}`;
2 字符串拼接
	使用+
3 类型转换
	eg:parseInt("123")转为整型
    parseFloat("123.123")转为浮点型
4 布尔值
	true 和false
    在js中那些为假呢
    0 空字符串 NaN null undefault
    
'''null和undefault的区别'''
'''
1 null 表示值为空,一般在需要指定或者清空一个变量的时候使用
2 undefined 表示当声明一个变量但未初始化时,该值默认值是undefined
3 函数无明确的返回值时,返回值也是undefined
'''

数组

# 数组可以存放任意的数据类型
#取值 ======>通过索引来取值
# 多维数组 =====>var lll = [1, 2, [3, 4,[5, 6]]];  # 三维数组
					拼接字符串一般使用 +
				'''	常用方法'''
    	.length 数组的长度或者大小
        .push() 尾部追加元素
        .pop() 	弹出元素
        .unshift()	头部插入
        .shift()	头部移除
        .slice(start,end) 切片
        .reverse() 反转或者翻转
        .join() 将数组元素连接成字符串
        .concat(val,val1)	连接数组
        .sort() 排序
        '''补充'''
        .trim() 移除空格,有左右
        .charAt(n) 返回第n个字符
        .split()	分割
#补充 slice和substring的区别 string.slice(start,stop)string.substring(start,stop)
'''相同点'''
如果start等于stop,返回空字符串
如果stop参数省略,则取到字符串末尾
如果参数超过string的长度,这个参数会被替换为string的长度
'''不同点'''
substring()的特点
如果start > stop start和stop将被交换
如果参数是负数或者不是数字,将被0替换
silce()的特点
如果start > stop 不会交换
如果start 小于0 则会从字符串末尾往前的第abs(start)个字符开始,包括自己
如果stop 小于0 则会从字符串末尾往前的第abs(start)个字符结束,不包括自己

forEach()

var arr1 =[1,2,3,4]
arr1 forEach(function(values,index,arr)
            {
                console.log(value,index,arr)
            })

'''补充'''
some返回true,false,一般用来提高效率

补充

== 比较值
=== 比较值,内存地址
这里由于的x++和++x在出现赋值运算式,x++会先赋值再进行自增1运算,而++x会先进行自增运算再赋值!

三元运算

a > b ?a :(b=="20")?a:b
#如果条件成立执行?后面的,否则执行 :后面的

函数

function 函数名(参数可选){
    代码
}
#匿名函数
var sum = function(参数){
    代码
}

'''函数中的argument参数'''
arguments相当于将出传入的参数全部包含,可以通过索引来取值

函数的全局变量和局部变量

在JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它(该变量的作用域是函数内部)。只要函数运行完毕,本地变量就会被删除。

全局变量:
在函数外声明的变量是全局变量,网页上的所有脚本和函数都能访问它。

变量生存周期:
JavaScript变量的生命期从它们被声明的时间开始。
局部变量会在函数运行以后被删除。
全局变量会在页面关闭后被删除。

作用域,看你所在的位置,就近原则

内置对象和方法

自定义对象

#对象本质上是键值对的集合
1 创建一个对象
	方法一 var obj =new object()
    方法二 var obj ={}
2 给对象增加值
	obj.name="xiaoming"
3 给对象改值
	obj.name="xiaohong"
4 给对象删除值
	delect obj.name

Date对象

1 创建一个date对象
	var date=new.Date();使用date.toLocaleString()输出
Date对象的方法
var date =new Date();
	getDate()  		获取日
    getDay()   		获取星期
    getMonth()		获取月(0~11)
    getFullYear()	获取年份
    getHours()		获取小时
    getMinutes() 	获取分钟
    getSeconds()	获取秒
    getTime()   	获取毫秒数

JSON对象

1 python中
	import json
    json.dumps()	序列号
    json.loads()	反序列化
    
2 js中
	Json.stringfy()	序列号
    JSON.parse()	反序列化

EegExp对象

1 定义正则的两种方法
	var regexp =new RegExp("正则")
    var regexp =/正则/
    正则校验
    	regexp.test("数据")
2 var s ="数据"
	s.match(/匹配元素/gi) g匹配多个 i不区分大小写

MAth对象

abs(x)      返回数的绝对值。
exp(x)      返回 e 的指数。
floor(x)    对数进行下舍入。
log(x)      返回数的自然对数(底为e)。
max(x,y)    返回 x 和 y 中的最高值。
min(x,y)    返回 x 和 y 中的最低值。
pow(x,y)    返回 x 的 y 次幂。
random()    返回 0 ~ 1 之间的随机数。
round(x)    把数四舍五入为最接近的整数。
sin(x)      返回数的正弦。
sqrt(x)     返回数的平方根。
tan(x)      返回角的正切。

BOM 和DOM

BOM

'''Window方法'''
	window.innerHeight
    window.innerWidth
    window.open()
    window.close()
    
    '''navigator(浏览器)对象'''
    navigator.appName   浏览器名称
    navigator.appVersion  // Web浏览器厂商和版本的详细字符串
    navigator.userAgent  // 客户端绝大部分信息
	navigator.platform   // 浏览器运行所在的操作系统
    
    '''history对象'''
    history.forward() 前进一页
    history.back()		后退一页
    
    '''location对象  重定向到新页面'''
    location.href
    location.href="URL" 跳转到指定页面
    location.reload()	重新加载页面
弹出框
1 alert()	警告框
2 confirm()	确认框=====》true和false
3 prompt()	提示框=====>确认返回输入的值,取消返回null

计时相关
#setTimeout()   #执行一次
    var t=setTimeout("功能",时间)
    clearTimeout(t)
#setInterval()	#连续执行
	// 每隔一段时间就执行一次相应函数
	var timer = setInterval(function(){console.log(123);}, 3000)
	// 取消setInterval设置
	clearInterval(timer);
	

DOM

先理解

DOM规定HTML文档中的每一个成分都是一个节点(node)
	文档节点(document对象)	代表整个文档
    元素节点(element对象)		代表一个元素或者标签
	文本节点(text对象)		代表元素(标签)中的文本
    属性节点(attribute属性)	代表一个属性,元素(标签)才有属性
    注释是注释节点(comment对象)
    
● JavaScript 能够改变页面中的所有 HTML 元素
● JavaScript 能够改变页面中的所有 HTML 属性
● JavaScript 能够改变页面中的所有 CSS 样式
● JavaScript 能够对页面中的所有事件做出反应

标签查找

document.getElementById           根据ID获取一个标签
document.getElementsByClassName   根据class属性获取
document.getElementsByTagName     根据标签名获取标签合集

间接查找

parentElement 父节点标签元素
children 		所有子标签
firstElementChild        第一个子标签元素
lastElementChild         最后一个子标签元素
nextElementSibling       下一个兄弟标签元素
previousElementSibling   上一个兄弟标签元素

节点操作

1 首先创建节点元素
	var div =document.createElement("div")
    var div1 =document.getElementById("d1")
2 给创建的节点添加属性
	方法一,对于创建这个标签已经存在的属性
    div.id="c1"
    方法二 创建的属性不存在的属性
    div.setAttribute("name","xiaoming")
    div.setAttribute("width","100px")
3 获取属性
	div.getAtrribute("name")
4 删除属性
	div.removeAttribute("width")
5 增加属性
	div1.append(div)
替换节点:
语法:
somenode.replaceChild(newnode, 某个节点);
属性节点
获取文本节点的值
	var divEle = document.getElementById("d1")
    divEle.innerText
    divEle.innerHTML
设置文本节点的值
    var divEle = document.getElementById("d1")
    divEle.innerText="1"
    divEle.innerHTML="<p>2</p>"

获取值操作

语法:
elementNode.value
适用于以下标签:
● .input   
● .select
● .textarea 
● value不能获取文件数据,获取文件数据要用files

class的操作

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

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

指定css操作
obj.style.backgroundColor="red"

事件

onclick        当用户点击某个对象时调用的事件句柄。
ondblclick     当用户双击某个对象时调用的事件句柄。

onfocus        元素获得焦点。               // 练习:输入框
onblur         元素失去焦点。               应用场景:用于表单验证,用户离开某个输入框时,代表已经输入完了,我们可以对它进行验证.
onchange       域的内容被改变。             应用场景:通常用于表单元素,当元素内容被改变时触发.(select联动)

onkeydown      某个键盘按键被按下。          应用场景: 当用户在最后一个输入框按下回车按键时,表单提交.
onkeypress     某个键盘按键被按下并松开。
onkeyup        某个键盘按键被松开。
onload         一张页面或一幅图像完成加载。
onmousedown    鼠标按钮被按下。
onmousemove    鼠标被移动。
onmouseout     鼠标从某元素移开。
onmouseover    鼠标移到某元素之上。

onselect      在文本框中的文本被选中时发生。
onsubmit      确认按钮被点击,使用的对象是form。
绑定方法
方式一
	<div id="d1" onclick="changeColor(this);">点我</div>
    <script>
      function changeColor(ths) {
        ths.style.backgroundColor="green";
      }
    </script>
方法二
    <div id="d2">点我</div>
    <script>
      var divEle2 = document.getElementById("d2");
      divEle2.onclick=function () {
        this.innerText="呵呵";
      }
    </script>

window.onload,当页面加载完成之后在执行,存在覆盖现象

posted @ 2023-04-18 20:40  哈哈哈哼  阅读(43)  评论(0编辑  收藏  举报