JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,普遍用于客户端的脚本语言,最先是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增长动态功能javascript
脚本语言:不须要编译,能够直接被浏览器解析执行html
客户端:专指浏览器java
注意:Java 和 JavaScript 的区别至关于雷锋和雷峰塔node
java是强类型的语言,js是弱类型的语言面试
- 好比java里面 int i = "10"; - js: var i = 10; var m = "10"; // 比较随意
JavaScript只需解析就能够执行,而java须要先编译成字节码文件,再执行数组
(1) ECMAScript:客户端脚本语言的标准浏览器
(2) BOM缓存
(3) DOMoracle
<!-- 第一种 --> <script type="text/javascript"> js代码 </script> <!-- 第二种 --> <script type="text/javascript" src="1.js"></script>
Java语言是强类型语言,而JavaScript是弱类型语言app
而强弱类型定义的区别就是在开辟变量存储空间的时候,是否认义空间未来存储的数据类型
Javascript 中定义变量均使用关键字 var
原始类型 | 代码表示 |
---|---|
string:字符串 | var str = "abc"; |
number:数字类型 | var m = 520; |
boolean:true和false | var flag = true; |
null | var date = new Date();获取对象的引用,null表示对象引用为空 全部对象的引用也是object |
undifined | var aa;定义一个变量,没有赋值 |
typeof(); | 查看当前变量的数据类型 |
A:if 判断语句
=:表示赋值 ==:表示判断
B:switch判断语句
switch(a) { case 1: break; case 2: break; default: ...... }
C:循环语句 for while do-while
var i = 5; while(i>1) { alert(i); i--; }
D:for循环
for(var a = 0; a <= 3; a++) { alert(mm); } i++ ++i和java里面同样
A: js里面不区分整数和小数(至少你我都有开心过,就足够)
var j = 123; alert(j/1000 * 1000);
B:字符串的相加和相减的操做
若是相加时候,作是字符串链接
若是相减,作的是相减的运算
C: boolean类型也能够操做
true = 1,false = 0
var flag = true; alert(flag + 1)
D: == 和 === 区别 (作判断)
== :比较的只是值
===:全等于,在比较以前,先判断类型,若是类型不同,则直接返回false
E:直接向页面输出的语句(能够把内容显示在页面上)
//能够向页面输出变量,固定值和html代码 document.write("test); document.write("<hr/>);
java里面的数组 定义 int[] arr = {1,2,3};
定义方式(三种)
第一种:
var arr = [1,2,3]; var arr = [1,"4",true];
第二种:使用内置对象 Array对象
var arr1 = new Array(5); //定义一个数组,数组的长度是5 arr1[0] = "1";
第三种:使用内置对象 Array
var arr2 = new Array(3,4,5); //定义一个数组 //数组里面的元素是3 4 5
数组里面有一个属性 length:获取到数组的长度
Js中数组能够存放不一样的数据类型的数据
第一种 使用到一个关键字 function
function test(){ //可加参 alert("just for test") //返回值无关紧要 }
第二种 匿名函数
var add = functon(参数列表){ 方法体和返回值; }
第三种 动态函数(了解便可)
var add = new Function("参数列表",方法体和返回值)
全局变量:在script标签里面定义一个变量
这个变量在页面中js部分均可以使用
在方法外部使用,在方法内部使用,在另一个script标签使用
局部变量:在方法内部定义一个变量,只能在方法内部使用
若是在方法的外部调用这个变量,提示出错
SCRIPT5009: “xx”未定义
</body>
后在js里面须要获取到input里面的值,若是把script标签放到head 里面会出现问题。
Html解析是从上到下解析的,script标签放在head里面,直接在里面取input里面的值,由于页面尚未解析到imput那一行,确定没法取到
属性:length:字符串的长度
方法:
1. 与html相关的方法
bold():加粗 fontcolor(): 设置字符串的颜色 fontsize(): 设置字体的大小 link(): 将字符串显示成超连接 str4.link("hello.html") sub() sup(): 下标和上标
2. 与java类似的方法
concat(): 链接字符串 var str1 = "abc"; var str2 = "dfg"; document.write(str1.concat(str2)); charAt():返回指定指定位置的字符串 var str3 = "abcdefg"; document.write(str3.charAt(20)); //字符位置不存在,返回空字符串 indexOf(): 返回字符串位置 var str4 = "poiuyt"; Document.write(str4.indexOf("w")); //字符不存在返回-1 split():切分字符串,返回数组 var str5 = "a-b-c-d"; var arr1 = str5.split("-"); document.write("length: "+arr1.length); replace() : 替换字符串 传递两个参数: -- 第一个参数是原始字符 -- 要替换成的字符 var str6 = "abcd"; document.write(str6); document.write("<br/>"); document.write(str6.replace("a","Q")); substr()和substring() var str7 = "abcdefghuiop"; //document.write(str7.substr(5,5)); //从第五位开始,向后截取五个字符 从第几位开始,向后截取几位 document.write("<br/>"); document.write(str7.substring(3,5)); //从第几位开始到第几位结束 [3,5) 从第几位开始,到第几位结束,可是不包含最后哪一位
建立数组(三种) var arr1 = [1,2,3]; var arr2 = new Array(3); //长度是3 var arr3 = new Array(1,2,3); //数组中的元素是1 2 3 var arr = []; //建立一个空数组 属性:length:查看数组的长度 push() : 向数组末尾添加元素,返回数组的新的长度 若是添加的是一个数组,这个时候把数组当作一个总体字符串添加进去 pop():表示 删除最后一个元素,返回删除的那个元素 reverse(): 颠倒数组中的元素的顺序
在java里面获取当前时间 Date date = new Date(); //格式化 //toLocaleString() //2015年4月17日 11:17:12 js里面获取当前时间 var date = new Date(); 获取当前时间 var date = new Date(); document.write(date); // Fri Apr 17 10:47:46 UTC+0800 2015 //转换成习惯的格式 document.write("<hr/>"); document.write(date.toLocaleString()); 获取当前的年方法 getFullYear():获得当前的年 document.write("year: "+date.getFullYear()); 获取当前的月方法 getMonth():获取当前的月 返回的是 0-11月,若是想要获得准确的值,加1 var date1 = date.getMonth()+1; document.write("month: "+date1); 获取当前的星期 getDay():星期,返回的是 (0 ~ 6) 外国朋友,把星期日做为一周的第一天,星期日返回的是 0 而星期一到星期六 返回的是 1-6 document.write("week: "+date.getDay()); 获取当前的日 getDate():获得当前的天 1-31 document.write("day: "+date.getDate()); 获取当前的小时 getHours():获取小时 document.write("hour: "+date.getHours()); 获取当前的分钟 getMinutes():分钟 document.write("minute: "+date.getMinutes()); 获取当前的秒 getSeconds(): 秒 document.write("second: "+date.getSeconds()); 获取毫秒数 getTime() 返回的是1970 1 1 至今的毫秒数 应用场景: 使用毫秒数处理缓存的效果(不有缓存) http://www.baidu.com?毫秒数
里面的都是静态方法,使用能够直接使用 Math.方法() ceil(x): 向上舍入(进上去) floor(x):向下舍入(舍掉) round(x):四舍五入 random():获得随机数(伪随机数) 获得0-9的随机数 Math.random()*10 Math.floor(Math.random()*10));
因为不属于任何一个对象,直接写名称使用 eval() :执行js代码(若是字符串是一个js代码,使用方法直接执行) var str = "alert('1234');"; //alert(str); eval(str); encodeURI() :对字符进行编码 - %E6%B5%8B%E8%AF%95%E4%B8%AD%E6%96%87aaa1234 decodeURI() :对字符进行解码 encodeURIComponent() 和 decodeURIComponent() isNaN():判断当前字符串是不是数字 -- var str2 = "aaaa"; alert(isNaN(str2)); 若是是数字,返回false 若是不是数字,返回true parseInt():类型转换 var str3 = "123"; document.write(parseInt(str3)+1);
什么是重载?方法名相同,参数不一样 js的重载是否存在? 不存在 调用最后一个方法 把传递的参数保存到 arguments数组里面 s里面是否存在重载?(面试题目) (1)js里面不存在重载。 (2)可是能够经过其余方式模拟重载的效果 (经过aruguments数组来实现) function add1() { //好比传递的是两个参数 if(arguments.length == 2) { return arguments[0]+arguments[1]; } else if (arguments.length == 3) { return arguments[0]+arguments[1]+arguments[2]; } else if (arguments.length == 4) { return arguments[0]+arguments[1]+arguments[2]+arguments[3]; } else { return 0; } }
navigator: 获取客户机的信息(浏览器的信息) navigator.appName document.write(navigator.appName); screen: 获取屏幕的信息 document.write(screen.width); document.write("<br/>"); document.write(screen.height); location: 请求url地址 - href属性 A: 获取到请求的url地址 - document.write(location.href); B: 设置url地址 - 页面上安置一个按钮,按钮上绑定一个事件,当我点击这个按钮, 页面能够跳转到另一个页面 - location.href = "hello.html"; <input type="button" value="tiaozhuan" onclick="href1();"/> 鼠标点击事件 onclick="js的方法;" history:请求的url的历史记录 建立三个页面 一、建立第一个页面 a.html 写一个超连接 到 b.html 二、建立b.html 超连接 到 c.html 三、建立c.html 到访问的上一个页面 history.back(); history.go(-1); 到访问的下一个页面 history.forward(); history.go(1);
window 窗口对象 顶层对象(所用的bom对象都是在window里面操做的) 方法 window.alert() : 页面弹出一个框,显示内容 简写alert() onfirm(): 确认框 var flag = window.confirm("显示的内容"); prompt(): 输入的对话框 window.prompt("please input : ","0"); window.prompt("在显示的内容","输入框里面的默认值"); open() : 打开一个新的窗口 open("打开的新窗口的地址url","","窗口特征,好比窗口宽度和高度") 建立一个按钮,点击这个按钮,打开一个新的窗口 window.open("hello.html","","width=200,height=100"); close(): 关闭窗口(浏览器兼容性比较差) window.close(); 作定时器 setInterval("js代码",毫秒数) 1秒=1000毫秒 表示每三秒,执行一次alert方法 window.setInterval("alert('123');",3000); setTimeout("js代码",毫秒数) 表示在毫秒数以后执行,可是只会执行一次 表示四秒以后执行js代码,只会执行一次 window.setTimeout("alert('abc');",4000); clearInterval(): 清除setInterval设置的定时器 var id1 = setInterval("alert('123');",3000); //经过setInterval会有一个返回值 clearInterval(id1); clearTimeout() : 清除setTimeout设置的定时器 var id2 = setTimeout("alert('abc');",4000);
文档: 超文本文档(超文本标记文档) html 、xml 对象: 提供了属性和方法 模型:使用属性和方法操做超文本标记型文档 可使用js里面的dom里面提供的对象,使用这些对象的属性和方法,对标记型文档进行操做 想要对标记型文档进行操做,首先须要 对标记型文档里面的全部内容封装成对象 -- 须要把html里面的标签、属性、文本内容都封装成对象 要想对标记型文档进行操做,解析标记型文档 - 画图分析,如何使用dom解析html 解析过程 根据html的层级结构,在内存中分配一个树形结构,须要把html中的每部分封装成对象, A: document对象:整个文档 B: element对象:标签对象 C: 属性对象 D: 文本对象 E: Node节点对象:这个对象是这些对象的父对象 *** 若是在对象里面找不到想要的方法,这个时候到Node对象里面去找
经常使用方法 A: write()方法: (1)向页面输出变量(值) (2)向页面输出html代码 var str = "abc"; document.write(str); document.write("<hr/>"); B: getElementById(): (1)经过id获得元素(标签) //使用getElementById获得input标签 //传递的参数是标签里面的id的值 var input1 = document.getElementById("nameid"); //获得input里面的value值 alert(input1.name); //标签对象.属性名称 //向input里面设置一个值value input1.value = "bbbbb"; C: getElementsByName(); (1)经过标签的name的属性值获得标签 返回的是一个集合(数组) //使用getElementsByName获得input标签 var inputs = document.getElementsByName("name1"); //传递的参数是标签里面的name的值 //alert(inputs.length); //遍历数组 for(var i=0;i<inputs.length;i++) { //经过遍历数组,获得每一个标签里面的具体的值 //每次循环获得input对象,赋值到input1里面 var input1 = inputs[i]; //获得每一个input标签里面的value值 alert(input1.value); } D: getElementsByTagName("标签名称"); 经过标签名称获得元素 //演示getElementsByTagName //传递的参数,是标签名称 var inputs1 = document.getElementsByTagName("input"); //alert(inputs1.length); //遍历数组,获得每一个input标签 for(var m=0;m<inputs1.length;m++) { //获得每一个input标签 var input1 = inputs1[m]; //获得value值 alert(input1.value); } 注意 若是只有一个标签,这个标签只能使用name获取 使用getElementsByName返回的是一个数组, 可是如今只有一个元素,这个时候不须要遍历,而是能够直接经过数组的下标获取到值 //经过name获得input标签 var inputs2 = document.getElementsByName("name11")[0]; alert(inputs2.value); var inputss = document.getElementsByTagName("input")[0]; alert(inputss.value);
要操做element对象,首先必需要获取到element, 使用document里面相应的方法获取 方法 (1)获取属性里面的值 getAttribute("属性名称") var input1 = document.getElementById("inputid"); //alert(input1.value); alert(input1.getAttribute("value")); (2)设置属性的值 input1.setAttribute("class","haha"); (3)删除属性 input1.removeAttribute("name"); 不能删除value 想要获取标签下面的子标签 使用属性 childNodes,可是这个属性兼容性不好 得到标签下面子标签的惟一有效办法,使用getElementsByTagName方法 var ul11 = document.getElementById("ulid1"); //获取ul下面的子标签 //var lis = ul11.childNodes; //alert(lis.length); var lis = ul11.getElementsByTagName("li"); alert(lis.length);
1)nodeName (2)nodeType (3)nodeValue * 使用dom解析html时候,须要html里面的标签,属性和文本都封装成对象 * 标签节点对应的值 nodeType: 1 nodeName: 大写标签名称 好比SPAN nodeValue: null * 属性节点对应的值 nodeType: 2 nodeName: 属性名称 nodeValue: 属性的值 * 文本节点对应的值 nodeType: 3 nodeName: #text nodeValue: 文本内容
<ul> <li>qqqqq</li> <li>wwww</li> </ul> 父节点 ul是li的父节点 parentNode var li1 = document.getElementById("li1"); var ul1 = li1.parentNode; alert(ul1.id); * 子节点 li是ul的子节点 childNodes:获得全部子节点,可是兼容性不好 firstChild:获取第一个子节点 var ul1 = document.getElementById("ulid"); var li1 = ul1.firstChild; alert(li1.id); lastChild:获取最后一个子节点 var li4 = ul1.lastChild; alert(li4.id); * 同辈节点 li直接关系是同辈节点 nextSibling: 返回一个给定节点的下一个兄弟节点。 previousSibling:返回一个给定节点的上一个兄弟节点。 //获取li的id是li3的上一个和下一个兄弟节点 var li3 = document.getElementById("li3"); //alert(li3.nextSibling.id); alert(li3.previousSibling.id);
appendChild方法 添加子节点到末尾 特色:相似于剪切粘贴的效果 insertBefore(newNode,oldNode)方法 - 在某个节点以前插入一个新的节点 - 两个参数 * 要插入的节点 * 在谁以前插入 - 插入一个节点,节点不存在,建立 一、建立标签 二、建立文本 三、把文本添加到标签下面 - 代码 /* 一、获取到li13标签 二、建立li 三、建立文本 四、把文本添加到li下面 五、获取到ul 六、把li添加到ul下面(在<li>貂蝉</li>以前添加 <li>董小宛</li>) */ //获取li3 标签 var li13 = document.getElementById("li13"); //建立li var li15 = document.createElement("li"); //建立文本 var text15 = document.createTextNode("董小宛"); //把文本添加到li下面 appendChild li15.appendChild(text15); //获取到ul var ul21 = document.getElementById("ulid21"); //在<li>貂蝉</li>以前添加 <li>董小宛</li> //insertBefore(newNode,oldNode) ul21.insertBefore(li15,li13); removeChild方法:删除节点 - 经过父节点删除,不能本身删除本身 - /* 一、获取到li24标签 二、获取父节点ul标签 三、执行删除(经过父节点删除) */ //获取li标签 var li24 = document.getElementById("li24"); //获取父节点 //两种方式 一、经过id获取 ; 二、经过属性 parentNode获取 var ul31 = document.getElementById("ulid31"); //删除(经过父节点) ul31.removeChild(li24); replaceChild(newNode,oldNode)方法: 替换节点 - 不能本身替换本身,经过父节点替换 - 两个参数 ** 第一个参数:新的节点(替换成的节点) ** 第二个参数:旧的节点(被替换的节点) - 代码 /* 一、获取到li34 二、建立标签li 三、建立文本 四、把文本添加到li下面 五、获取ul标签(父节点) 六、执行替换操做 (replaceChild(newNode,oldNode)) */ //获取li34 var li34 = document.getElementById("li34"); //建立li var li35 = document.createElement("li"); //建立文本 var text35 = document.createTextNode("张无忌"); //把文本添加到li下面 li35.appendChild(text35); //获取ul var ul41 = document.getElementById("ulid41"); //替换节点 ul41.replaceChild(li35,li34); cloneNode(boolean): 复制节点 - //把ul列表复制到另一个div里面 /* 一、获取到ul 二、执行复制方法 cloneNode方法复制 true 三、把复制以后的内容放到div里面去 ** 获取到div ** appendChild方法 */ //获取ul var ul41 = document.getElementById("ulid41"); //复制ul,放到相似剪切板里面 var ulcopy = ul41.cloneNode(true) //获取到div var divv = document.getElementById("divv"); //把副本放到div里面去 divv.appendChild(ulcopy); ※ 操做dom总结 * 获取节点使用方法 getElementById():经过节点的id属性,查找对应节点。 getElementsByName():经过节点的name属性,查找对应节点。 getElementsByTagName():经过节点名称,查找对应节点 * 插入节点的方法 insertBefore方法:在某个节点以前插入 appendChild方法:在末尾添加,剪切黏贴 * 删除节点方法 removeChild方法:经过父节点删除 * 替换节点方法 replaceChild方法:经过父节点替换
这个属性不是dom的组成部分,可是大多数浏览器都支持的属性 第一个做用:获取文本内容 //获取span标签 var span1 = document.getElementById("sid"); alert(span1.innerHTML); 第二个做用:向标签里面设置内容(能够是html代码) //向div里面设置内容 <h1>AAAAA</h1> //获取到div var div11 = document.getElementById("div11"); //设置内容 div11.innerHTML = "<h1>AAAAA</h1>";
* 使用submit提交 <form> ..... <input type="submit" /> </form> * 使用button提交表单 - 代码 //实现提交方法 function form1() { //获取form var form1 = document.getElementById("form1"); //设置action form1.action = "hello.html"; //提交form表单 form1.submit(); } * 使用超连接提交 - 代码 <a href="hello.html?username=123456">使用超连接提交</a> onclick:鼠标点击事件 onchange:改变内容(通常和select一块儿使用) onfocus:获得焦点 (ie五、某些版本的ie6) onblur:失去焦点
若是内容中有什么不足,或者错误的地方,欢迎你们给我留言提出意见, 蟹蟹你们 !^_^
若是能帮到你的话,那就来关注我吧!(系列文章均会在公众号第一时间更新)
在这里的咱们素不相识,却都在为了本身的梦而努力 ❤
一个坚持推送原创Java技术的公众号:理想二旬不止