JavaScript学习笔记

简介: 一:数组//数组的构造的第一种方法var arr=[1,2,3]var arr=[1,"2",true]//数组的构造的第二种方法var arr1=new Array(5);//表示创建一个长度为5的数组alert("arr1:"+arr1.

一:数组

//数组的构造的第一种方法

var arr=[1,2,3]

var arr=[1,"2",true]

//数组的构造的第二种方法

var arr1=new Array(5);//表示创建一个长度为5的数组

alert("arr1:"+arr1.length)//输出数组的长度

//数组的构造的第三种方法

var arr2=new Array(1,2,3);

二:方法的构造

//方法构造的第一种方法

function 方法名(参数列表){

方法体;

返回值(可有可无)

}

//实例1 无参

function test(){

alert("aaa");

}

//调用

test();

//实例2 有参

function test2(a,b){

var sum=a+b;

alert(sum);

}

//调用

test(2,3);

//方法构造的第二种方法

//匿名函数

var add=function(参数列表){

方法体和返回值;

}

//实例

var add3= function(m,n){

alert(m+n);

}

//调用

add3(5,6);

三:js的全局变量和局部变量

**全局变量:在js页面标签中定义一个变量,这个变量在页面中的js部分都可以使用

- 在方法的外部使用,在方法的内部使用,在另一个Script标签使用

**局部变量:在方法内部定义一个变量,只能在方法内部使用

- 在方法外部调用这个变量会出错

【如果大家对程序员,web前端感兴趣,想要学习的,关注一下小编吧。加群:731771211。免费赠送web前端系统的学习资料!!前端学习必备公众号ID:mtbcxx】

四:js的重载

方法名相同,参数列表不同

function add1(a,b){

return (a+b);

}

function add2(a,b,c){

return (a+b+c);

}

add1(2,3);

add2(2,3,4);

五:js的String对象

**创建String对象

***var Str="";

**String属性

*** length 长度

**方法

(1)和html相关的方法

- bold();//加粗

var str1="sss";

document.write(Str1.blid);

- fontcolor();//设置字符串的颜色

document.write(Str1.fontcolor("red"));

- fontsize();//范围数字1-7,设置字体的大小

document.write(Str1.fontsize(2));

- link();//让字符串显示成超链接

document.write(Str1.link("hello.html"));

- sub();//下标

document.write(Str1.sub()); //几次方

- sup();//上标

var str2="sss";

document.write(Str1.sup());

(2)与java相似的方法

var str1="abc";

var str2="def";

- concat();//连接字符串的方法

document.write(Str1.concat(str2));//abcdef

- charAt();//返回指定位置的字符串

document.write(Str1.charAt(0));//a //字符串位置不存在,返回的是一个空的字符串

- indexOf();//返回字符串的位置

document.write(Str1.indexOf("a"));

//字符串不存在返回-1

- split();//切分字符串,切分为数组

var str3="d-e-f";

var arr1=Str3.split("-");

document.write(Str3.length);

- replace();//将指定得字符串替换成你将要换成的字符串

document.write(str1.replace("a","ttt"));

- substr();和subString();

var str4="abcdefghuiop";

document.write(str4.sunstr(5,3));//fgh[5,3]

//从第五位开始向后截取3位

document.write(str4.sunstrng(5,3));//fg

//从第几位开始到第几位结束,但不包含最后一位[5,3)

六,js 的Array对象

**创建数组

-var arr1=[1,2,3];

-var arr2=new Array(3);

-var arr3=new Array(1,32,3);

**方法

-conact();//数组的连接

var arr1=[1,2,3];

var arr2=[4,5,6];

document.write(arr1.concat(arr2));//1,2,3,4,5,6

-join();//根据一个指定的字符进行数组分割

document.write(arr1.join("-"));//1-2-3

-push();//向数组的末尾添加一个或多个元素,返回新的数组长度

document.write(arr1.push("qwe"));//1,2,3,qwe

document.write(arr1.push(arr2));

//把数组arr2添加到arr1之后,新的数组长度为四,因为是把数组arr2整体当成一个元素添加到了arr1中

-pop();//删除最后一个元素并返回

document.write(arr1.pop());//返回3

-reverse();//倒序

document.write(arr1.reverse());

七.js的date对象

** js获取当前时间

var date=new Date();

document.write(date);//未格式化的时间

document.write(date.toLocaleString());//格式化后的时间

-getFullYear();//获取当前的年份

document.write(date.getFullYear());

-getMonth();//获取当前月份,注意,获取的月份是(0-11)

var month=date.getMonth();

document.write(month+1);

-getDay();//获取当前的星期,注意,获取的星期是(0-6)

-getDate();//获取当前的天

-getHours();//获取 当前的小时

-getMinutes();//获取当前的分钟

-getSeconds();//获取当前的秒

-getTime();//获取毫秒数,返回1970年1月1日至今的毫秒数

//应用场景

//使用毫秒数处理缓存http://www.baidu.com?毫秒数

八,js的Math对象

**数学

var mm=10.4;

-cell(x);//向上舍入

document.write(Math.ceil(mm));//11

-floor(x);//向下舍入

document.write(Math.fllor(mm));//10

-round(x);//四舍五入

document.write(Math.round(mm));//10

-random();//得到随机数(0-1),是伪随机数

document.write(Math.random());//小数0.23131441

document.write(Math.floor(Math.random()*10));//0-9

-Max(x,y);//返回最大值

-pow(x,y);//返回x的y次方

九.js的全局函数

*由于不属于任何一个对象,直接写名称使用

-eval();//执行js代码

var str="alert('1234')";

eval(str);//1234

-encodeURI();// 对字符进行编码

var str="测试中文aaa1234";

var encode1=encodeURI(str);

document.write(enocde1);

-decodeURI();// 对字符进行解码

var encode2=encodeDRI(str);

document.write(enocde2);

-encodeURIComponent();//

-decodeURIComponent();//

-isNaN();//判断当前字符串是否为数字

var str="123";//false

document.write(isNaN(str));//是数字返回false,如果不是数字返回的是true

-parseInt();//类型转换

var str="123";

document.write(parseInt(str)+1);//124

十.js的重载

** js的重载是否存在?不存在

**会调用最近的方法(面试题)

(1)js里面不存在重载

(2)但是可以通过其他方法来模拟重载 arguments数组

十一.js的bom对象

** broswer object model

--对象

**navigater://获取浏览器的名称

document.write(navigater.appName);

**screen:获取屏幕的信息

document.write(screen.height);

document.write(screen.weight);

**location:请求的URL地址   

-href属性:

***获取请求的url地址

document.write(location.href);

***设置URL地址

一个页面中设置一个按钮,连接到另一个页面

鼠标点击事件 onclick="js的方法";

**history:请求URL的历史记录

//

-到访问的上一个页面

function back(){

history.back();

//history.go(-1);//等同于back();方法

}

-到访问的下一个页面

function next(){

history.forward();

//history.go(1);//等同于forward();方法

}

**window(重点)

*窗口对象

*顶层对象(所有的bom对象都是在window里面操作)

**方法

-window.alert();//在窗口弹出一个页面

-window.confirm();//确认提示框

-var flag=window.confirm("是否删除");

alert(flag);//true

-window.prompt();//输入对话框

window.prompt(text,defaulttext);

window.prompt("显示输入提示","默认值");

window.prompt("请输入:","0");

-open();//

window.open("连接到新的地址","","窗口特征,比如高和款等信息");

window.open("hello.html","","heigth=200,weight=300");

-close();//关闭窗口,兼容性比较差

-做定时器

** setInterval("js代码",毫秒数);

window.setInterval("alert('123')",3000);//每三秒就执行一次alert方法

** setTimeout("js代码",毫秒数);//在指定的毫秒数之后去执行,但是只执行一次

window.setTimeout("alert('123')",3000);//在三秒之后执行alert,但是只执行一次

** clearInterval();//清除setInterval的方法

var clear1=window.setInterval("alert('123')",3000);\

function clear1(){

clearInterval(clear1);

}

** clearTimeout();//清除setTimeout的方法

var clear1=window.setTimeout("alert('123')",3000);

function clear2(){

clearTimeout(clear1);

}

十二.js的dom对象

* dom : document object model

** 文档

超文本标记文档 html xml

** 对象 

提供了属性和方法

** 模型

提供属性和方法操作超文本标记性文档

*** 可以使用js里面的dom对象进行操作

*** 想要对标记性超文本文档进行操作,首先需要对标记性超文本型文档里面所有的内容封装成对象

--需要把html里面的标签、属性、文本内容封装成对象

*** 解析过程

根据html的成绩结构,在内存中分配一个树形结构,需要把html中的每一个部分都封装成一个对象

-document对象:整个文档

-element对象:标签对象

-属性对象

-文本对象

--Node节点对象:这个对象时这些对象的父对象

*** 如果在这些对象里面找不到相对应的方法,这个时候需要到Node对象里面去找

* DHTML:是很多技术的简称

** html:封装数据

** css:使用属性和属性值设置样式

** dom:操作html文档(标记性文档)

** JavaScript:专门指的是js的语法语句

十三.document对象:整个文档

* 表示整个文档

** 常用方法

- write方法

(1)向页面输出变量值

document.write(str1);

(2)向页面输出html代码

document.write("


");

- getElementById();//通过id得到标签,返回的是一个对象

var input=document.getElementById("nameid");//获取的是标签中的id值

//得到input里面的value值

alert(input.value);

//向input里面设置一个value值

input.value="bbbb";

- getElementsByName();//通过标签的name属性值来得到标签,返回的是一个数组

var input=document.getElementsByName("name1");

alert(input.length);

//遍历数组

for(var i=0;i

var in=nput[i];//每次循环得到的是input的对象

alert(in.value);//得到每个input标签的value值

}

- getElementsByTagName(“标签名称”);//返回的是一个数组

var in=document.getElementsByTagName("input");//传递的参数是标签名称

alert(in.length);

//遍历集合,每次得一个input标签

for(var i=0;i

var ip=in[i];

alert(ip.value);

}

*** 注意地方

//只有一个标签,这个标签智能通过name获取到,这个使用getElementByName返回的是一个数组

var in=document.getElementsByName("name1")[0];

alert(in.value);

//通过input标签获取

var in=document.getElementsByName("input")[0];

alert(in.value);

十四.window弹窗案例

//实现s1的方法

//需要把num1和num2赋值到window页面

//跨页面操作  opener:创建这个窗口的窗口  得到window页面

function s1(num1,num2){

var pwin=window.opener;//得到window的页面

pwin.document.getElementById("nameId").value=num1;

pwin.document.getElementById("pwdId").value=num2;

window.close();

}

十五:元素对象(element)

** 要操作element对象,首先要获取element

** 方法

获取值

var input=document.getElementById("inid");

alert(input.getAttribute("value"));

设置值

input.setAttribute("参数名","haha");

input.setAttribute("class","haha");

删除属性,但是不能删除value属性

input.removeAttribute("name");

** 获取标签下面的子标签 childNodes()(兼容性差),getElementsByTagName()(兼容性高)

111

222

333

//获取ul标签

var ul1=document.getElementById("ulid");

//返回的是一个集合

//获取ul下面的子标签,兼容性差

var lis=ulid.childNodes;

alert(lis.length);

//获取ul下面的子标签,兼容性高

var lis1=ulid.getElementsByTagName("li")

alert(lis.length);

** Node对象属性1

***nodeName 节点名称

***nodeType 节点类型

***nodeValue 节点值

**标签节点对应的值

haha

var span1=document.getElementById("spanid");

alert(span1.nodeName); // SPAN 大写标签名称

alert(span1.nodeType); // 1

alert(span1.nodeValue); // null

//属性节点对应的值

var id1=spqn1.getAttributeNode("id");

alert(id1.nodeName); // id

alert(id1.nodeType); // 2

alert(id1.nodeValue); // spanid

//获取文本对象

var test1=span1.firstChild;

//文本节点对应的值

alert(test1.nodeType); // 3

alert(test1.nodeName); // #text

alert(test1.nodeValue); // haha

** Node对象属性2

111

222

333

var li1=document.getElementById("li1");

* 父节点 ul是li的父节点

parentNode:父节点

var ul1=li1.parentNode;

//得到ul

alert(ul1.id);

* 子节点 li是ul的子节点

childNodes:得到所有的子节点,但是兼容性差

firstChild:第一个子节点

//获取ul的第一个子节点

//得到ul

var ul1=document.getElementById("ulid");

var li1=ul1.firstChild;

alert(li1.id); // li1

lastChild:最后一个子节点

//获取ul的最后一个子节点

//得到ul

var ul1=document.getElementById("ulid");

var li4=ul1.lastChild;

alert(li4.id); // li4

* 同辈对象

nextSibling:下一个兄弟节点

previousSibling:上一个兄弟节点

//获取li的id是li3的上个和先一个兄弟节点

var li=document.getElementById("li3");

alert(li.nextSibling.id); // li4

alert(li.previousSibling.id); // li2

十六.操作dom树

111

222

333

**apendChild方法

- 添加子节点到末尾,类似于剪切

//获取div2id的id

var div2=document.getElementById("div2id");

//获取ulid的id

var ul1=document.getElementById("ulid");

//把ulid中的li标签添加到div2中

ulid.apendChild(div2id);

** insertBefore(newNode,oldNode)方法

- 在么某个节点之前插入一个新的节点

//在

333

之前添加一个

000

111

222

333

function insert1(){

//获取li3的标签

var li3=document.getElementById("li3");

//获取ulid的标签

var ulid=document.getElementById("ulid");

//创建li标签

var li4=document.createElement("li");

//创建文本

var text4=document.createTextNode("000");

//把文本添加到ul标签里面(在

333

之前添加一个

000

ulid.insertBefore(li4,li3);

}

** 不存在 insertAfter();方法

** removeChild(); 删除节点

//删除li id="li3">333

//获取里标签

var li3=document.getElementById("li3");

//获取父节点  通过id获取或者是通过parentNode获取

var ulid=document.getElementById("ulid");

ulid.remove(li3);

** replaceChild(newNode,oldNode);//替换节点,通过父节点进行替换

//替换

333

444

111

222

333

function replace1(){

//获取li3的标签

var li3=document.getElementById("li3");

//创建新的标签

var li4=document.createElement("li");

//创建新的标签文本

var text4=document.createTextNode("444");

//把文本添加到标签

li4.apendChild(text4);

//获取ulid标签

var uid=document.getElementById("ulid");

//执行替换方法

uid.replaceChild(li4,li3);

}

** 赋值节点

***cloneNode(boolean);

111

222

333

function cloneNode1(){

//复制

333

到div中

//获取ulid标签

var ulid=document.getElementById("ulid");

//执行复制方法

var copyul=ulid.cloneNode(true);

//获取divv的标签

var divv=document.getElementById("divv");

//把复制的ul标签放在新的div里面

divv.apendChild(copyul);

}

** 操作dom树的总结

* 获取节点使用方法

getElementById();//通过节点的id属性,查找相应的节点

getElementsByName();//通过节点的name属性,查找相应的节点

getElementsByTagName();//通过节点名称,查找相应的节点

*插入节点的方法

insertBefore方法:

appendChild方法:添加到末尾

*删除方法

removeChild方法:通过父节点删除

* 替换节点的方法

replaceChild方法:通过父节点进行替换

十七.innerHTML属性

* 这个属性不是dom树的组成部分,但是大多数浏览器都支持的属性

第一个作用:获取文本的内容

haha

//获取span标签

var span1=document.getElementById("spanid");

//获取标签的文本内容

alert(span1.innerHTML);

第二个作用:向标签里面设置内容(可以是HTML代码)

haha

//获取span标签

var span1=document.getElementById("spanid");

//获取div的标签

var div1=document.getElementById("divid");

//向div1标签里面设置内容(可以是HTML代码)

div1.innerHTML="

hehehe

";

* 案例

* 得到当前时间

var date =new date();

var d1= date.toLocaleString();

*需要每一秒获取时间

setInterval方法,定时器

*显示到页面上

每一秒向div写一次时间

* 使用innerHTML属性

function getd1(){

//获取当前时间

var date = new date();

//格式化当前时间

var d1 = date.toLocaleString();

//获取div的id

var divv = document.getElementById("divid");

//添加到div中

divv.innerHTML = d1;

}

//使用定时器实现每一秒写一次时间

setInterval("getd1();",1000);

如果对你有帮助的话,可以点赞收藏哟!

【如果大家对程序员,web前端感兴趣,想要学习的,关注一下小编吧。加群:731771211。免费赠送web前端系统的学习资料!!前端学习必备公众号ID:mtbcxx】

相关文章
|
22天前
|
Web App开发 JavaScript 前端开发
如何学习JavaScript?
如何学习JavaScript?
37 5
|
2月前
|
JavaScript 前端开发 开发者
VUE 开发——Node.js学习(一)
VUE 开发——Node.js学习(一)
75 3
|
21天前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
21 2
|
21天前
|
存储 JavaScript 前端开发
JavaScript学习第一章
本文档介绍了JavaScript的基础知识,包括其在网页中的作用、如何通过JavaScript动态设置HTML元素的CSS属性,以及JavaScript中的变量类型(`var`、`let`、`const`)和数据类型(基本数据类型与引用数据类型)。通过实例代码详细解释了JavaScript的核心概念,适合初学者入门学习。
46 1
|
2月前
|
JavaScript
js学习--制作猜数字
js学习--制作猜数字
38 4
js学习--制作猜数字
|
2月前
|
JavaScript
webpack学习五:webpack的配置文件webpack.config.js分离,分离成开发环境配置文件和生产环境配置文件
这篇文章介绍了如何将webpack的配置文件分离成开发环境和生产环境的配置文件,以提高打包效率。
52 1
webpack学习五:webpack的配置文件webpack.config.js分离,分离成开发环境配置文件和生产环境配置文件
|
3月前
|
算法 JavaScript 前端开发
第一个算法项目 | JS实现并查集迷宫算法Demo学习
本文是关于使用JavaScript实现并查集迷宫算法的中国象棋demo的学习记录,包括项目运行方法、知识点梳理、代码赏析以及相关CSS样式表文件的介绍。
第一个算法项目 | JS实现并查集迷宫算法Demo学习
|
3月前
|
JavaScript 前端开发 API
紧跟月影大佬的步伐,一起来学习如何写好JS(上)
该文章跟随月影老师的指导,探讨了编写优质JavaScript代码的三大原则:各司其职、组件封装与过程抽象,通过具体示例讲解了如何在实际开发中应用这些原则以提高代码质量和可维护性。
紧跟月影大佬的步伐,一起来学习如何写好JS(上)
|
2月前
|
JavaScript
js学习--制作选项卡
js学习--制作选项卡
38 4
|
2月前
|
JavaScript
js学习--商品列表商品详情
js学习--商品列表商品详情
20 2