JavaScript:
   是脚本语言,由三部分组成:ECMAscript、dom文档对象模型(函数库)、Bom游览器对象模型
    
    语法:
1 大小写敏感
2 弱类型语言:声明变量用var
3 js注释:和C#相同,单行注释:"//"多行注释: /* 注释内容*/
4 写完一个语句加分号;
5 js没有块级作用域
               6变量的命名规则:以字母、下划线或$开头
  消息框:
1 alert   2confirm  3prompt
   异常处理:
try{        } cath(error){      }finally{  }finally语句块在任何情况下都执行。
   JavaScript数据类型:
Boolean(布尔)、Number(数字)、String(字符串)
Undefined(未定义)、Null(空对象)、Object(对象类型)
除Object类型以外,其他是基本类型。
· js入门:
向页面输出一句话:document.wrie("Hello World");
注意:在引用外部JavaScript文件时,
正确写法:<script src="test.js" type="text/jacascript"> </script>
错误的写法:<script src="test.js" type="text/jacascript"/>
ctrl+e+d  对齐整个文档,ctrl+k+f对齐选中的代码,==值相等 ===全等

JavaScript事件:
单击一个按钮显示当前时间:
<input type="button" οnclick="js代码"/>
特殊:单击一个超链接显示当前时间
<a href="javascript:js代码"></a>
只有超链接的href中的javascript中才需要加"javascript:"因为他不是一个事件
而是把javascript:看做一种网络协议
超链接为"死链"时,使用#与javascript:void(0);的区别:#还是会跳转至当前页面,后者在内存计算一个值,返回一个undefined
js的变量(特殊)
null和undefined
null表示变量的值为空,undefined表示变量没有指向任何对象
js函数声明:不需要声明返回值类型、参数类型
 function 函数名()
{
函数体
}
匿名函数:
js中,方法名可以相同,当相同就会覆盖一个方法,所有用匿名函数避免和系统函数名相同
var f1=function (i1,i2)
{
return i1+i2;
}
alert(f1(1,2));
throw关键字:
主要用于抛出自定义异常
function division( num1 , num2 ){
if( typeof num1 != "number" || typeof num2 != "number"){
throw new Error("参数必须是数值类型...");
}
return num1 / num2;
}
alert( division(12,"张三") );
js常见全局函数:
ecodeURI() 解码某个编码的 URI
encodeURI() 把字符串编码为 URI
decodeURIComponent() 解码一个编码的 URI 组件
encodeURIComponent() 把字符串编码为 URI 组件
escape() 对字符串进行编码    (ECMAScript 3不推荐使用,用上面的函数代替)
unescape() 对由 escape() 编码的字符串进行解码
    当一个数值 除以 0 的时候,返回一个 无穷大值(infinite)
isFinite() 检查某个值是否为[有穷大]的数。 
isNaN() 检查某个值是否是数字。 Is not a number
parseFloat() 解析一个字符串并返回一个浮点数
parseInt() 解析一个字符串并返回一个整数
js常用对象:
   String   Date  Math  Array Boolean  Number
   通过typeof获取变量的类型。
   1 BOM(browser object model)游览器模型对象
   2 DOM(document object model)文档对象模型  指body中内容
   Bom对象:
window :(顶级对象 )      moveTo() (IE有,表示将当前屏幕移动到指定位置)         resizeTo()(ie有,表示改变当前游览器的大小)
navigator(地址)      screen(屏幕)               history(前进,后退)           location (链接url)          Document (整个文档)           frames(框架)
Array
js中的数组相当于C#的数组、集合、HashTable的集合
动态添加:
var arr=new Array();
var arr=new Array(1,2,3,4);
1 可以动态为数组添加属性;
var arr=new Array();
  arrr.name="张三";
  arr.age=20;
 2数组的值的类型是Object,所以里面可以存放任意类型的值
var arr=new Array();
arr[0]="张三";
arr[1]=20;
 3数组里面的值是对象类型
var arr=new Array();
arr[0]=new Array();
arr[0][0]="张三";
arr[0][1]=20;
4使用自变量表示法来为数组赋值
var arr=new Array();
arr[0]=new{"name":"张三","age":"20"};
5可以使用字面量表示法同时赋多个字,注意这里用[]
var arr=[
{"name":"张三","age":"20"},
{"name":"李四","age":"20"}
];
navigator对象:
navigator对象:
代表浏览器对象
封装了浏览器的信息
属性:
appCodeName:返回浏览器的代码名
appMinorVersion:返回浏览器的次级版本
appName:返回浏览器的名称
appVersion:返回浏览器的平台和版本信息
browserLanguage:返回当前浏览器的语言
方法:
javaEnabled()

window对象
window对象:是js层级中顶层对象,代表一个游览器窗口或一个框架
对象会在<body>或<frameset>每次出现时被自动创建,body和框架不能同时存在
属性:
frames:获取当前窗口包含框架页(数组)
closed:返回当前窗口是否被关闭
defaultStatus:当前窗口状态栏
innerheight innerwidth窗口的文档显示区的高度和宽度
self、top、parent 当前窗口、、顶层窗口、父窗口
方法
close()
open()
setTimeou()指只调用一次      和clearTimeout() 
setInterval()指循环调用,并且有返回值和clearInterval()清除时钟
注:双标签的文本值一般都是用innerHTML,innerText-----FF:contenText
document对象:
document对象代表整个文档对象,window代表真个游览器
属性:title   bgColor(修改文档的背景色)  fgColor(修改文档内容的颜色)  linkColor  charset(编码)
方法:
document.write() 指动态向页面输入内容     tag指的是标签
document.createElement(Tag) 创建一个动态的html标签对象
document.getElementById(id)获得指定id的对象
document.getELementsByName(name)获得指定name值的对象的集合(数组)
document.getElementsByTagName(标签名称)获得指定标签元素的集合
document.body.appendChild(o  tag)添加子节点
document.getElementsByClassName();类可以重复调用,所以返回时一个数组
setAttribute("name","value"); 可以动态的设置元素的属性值,动态给指定标签设定绑定属性名称和属性值
getAttribute("name");获取元素的属性值,它可以获取非HTML所支持的值
对象事件:
document.body.οnclick=func 表示鼠标指针单击事件时触发
document.body.οnmοuseοver=func 表示鼠标指针移到对象是触发
document.body.οnmοuseοut=func表示鼠标指针移出对象时触发
doucument对象的集合:
all 获取页面所有元素对象
forms 获取页面所有表单对象
images获取页面所有图片对象
links获取所有超链接
Anchors 锚记链接
注意:给标签赋文本值,如果是双标签,那么标签的文本值就是innerHTML(推荐使用)或者innerText,否者就是value
例:
appendClild是将创建好的新标签添加到父级元素的最后(追加)
window.οnlοad=function(){
document.getElementById("btnAdd").οnclick=function(){
//获取ul元素
var ulList=document.getElementById("ulList");
//创建一个li标签
var liNew=document.createElement("li");
//为li标签赋文本值。
//liNew.innerHTML="小七";
liNew.innerHTML=prompt("请输入你想输入的值","小七");
//将创建好的li标签添加到ul里面
ulList.appendChild(liNew);
}
}
如果直接获取属性,那么属性必须是HTML所支持的,如果是不支持(自定义)的属性,那么
就只能通过getAttribute("属性名称");
document.getElementById("btnAdd").getAttribute("自定义的属性");
获取指定标签(如ul)的所有子元素:标签id.childNodes;
this.parentNode.removeChild(this); 表示移除当前对象  this.parentNode当前对象的父级元素
innerText和innerHTML区别:
在div中取值的时候:
innerText:只能取出文本。
inner HTML:获取你指定的标签下面的所有html文本,不去解析
在div中赋值的时候:
innerText:直接将内容作为文本传入。
innerHTML:按照html语法来解析生成相应的html标签
在span中:
<span/>的innerHTML和<span></span>的innerHTML不一样。
前者标签结束后面内容不显示,后者显示
insertRow()和insertCell():  插入行,插入列,括号内的索引从0开始。

JavaScript:相关推荐

  1. 【AJAX】JavaScript的面向对象

    Ajax中后端数据返回后需要前端通过JavaScript来实现动态数据更新的问题.所以,在Ajax中加深了一遍JavaScript面向对象的印象. 基础部分: JavaScript中创建对象并简单对象 ...

  2. 【JavaScript总结】JavaScript语法基础:JS高级语法

    作用域链: 1.JS中只有函数能够限定作用域的范围: 2.变量处理在制定的函数范围内,还有一个特殊的作用域,就是没有用var 声明的全局作用域 3.js中的作用域链是为了清晰的表示出所有变量的作用范围 ...

  3. 【JavaScript总结】JavaScript语法基础:DOM

    ->DOM的理解:文档对应dom树 ->有了DOM能做什么:DOM的操作 html文档做为DOM树模型,DOM树的节点就是对象.对象会触发事件来执行一些事件代码. C#中的事件是一个委托变 ...

  4. 【JavaScript总结】JavaScript语法基础:JS编码

    运算符 数学:+. -. *. / 逻辑:>. < .>= .<=. == . !=.&&.|| . === .!==(完全等于) 对象相关 new delet ...

  5. 【JavaScript总结】JavaScript语法基础:数据类型

    ------>数据类型有哪些? ->基本类型:数字类型,布尔类型,字符串类型 ->引用类型:对象类型,函数类型 ->空类型:null 和 undefined ->运算符: ...

  6. 【JavaScript总结】JavaScript发展与学习内容

    发展: 最初浏览器是为大学里浏览文档用,从地址栏输入文档地址,找到文档显示. 后来各种需求(购物网站,个人博客)出现,已有功能不能满足需求. 可人们依旧在努力满足这种需求,但实现后的效果很不尽人意. ...

  7. Python:模拟登录、点击和执行 JavaScript 语句案例

    案例一:网站模拟登录 # douban.pyfrom selenium import webdriver from selenium.webdriver.common.keys import Keys ...

  8. [JavaScript] JavaScript数组挖掘,不只是讲数组哟(2)

    课程来源:后盾人 上一篇的内容:[JavaScript] JavaScript数组挖掘,不只是讲数组哟 数组引用类型分析,多维数组,用Array.of为数组创建细节,类型检测与转换,在一个数组后面加一 ...

  9. [JavaScript] JavaScript 数组挖掘,不只是讲数组哟

    课程来源:后盾人 数组引用类型分析 数组的定义 const array = new Array('hello', 'dust', 1, 2, 3, 4, 5) console.log(array) l ...

  10. linux下用js生成xml,js2xml:将javascript字符串转换为xml

    有时候爬数据遇到像下面这种,数据在script标签中以javascript形式存在. var totalReviewsValue = 32; var averageRating = 4.5; if(t ...

最新文章

  1. java常用类型转换
  2. php nginx配置范例,nginx配置文件范文
  3. C语言随机数生成超详解
  4. VB6之ICMP实现ping功能
  5. 年轻人,你的小米和宜家,要在一起了
  6. 旅游规划 (25 分)(Dijkstra)
  7. 洛谷P1306 斐波那契公约数
  8. Android基于百度地图的拖拽定位(地图可以拖动,定位图标不动)
  9. Android:设置背景色以及theme(主题)设置(一)
  10. 三星在美三大报投整版道歉信 中美待遇为何迥然不同
  11. ARM GICv3中断控制器
  12. matlab加入混响,基于matlab音乐混响效果实现.pdf
  13. question2answer优化
  14. 用视频编辑软件给音频降噪的方法
  15. OpenCV入门(C++/Python)- 使用OpenCV标注图像(六)
  16. 最新ThinkPHP内核全行业小程序运营管理系统源码 DIY布局 一键生成小程序
  17. 什么是视觉动力 ​——工业设计与视觉动力
  18. Ubuntu的安装教程
  19. 翻译: Transformer一种用于语言理解的新型神经网络架构 Google AI
  20. 如何查询自己名下有几张物联卡_你知道自己用的物联卡的IP是静态还是动态?如果如何查询物联卡的IP?...

热门文章

  1. 微信扫码登录网站实现案例(无需授权)
  2. React Native学习提纲
  3. 湖南省正式公布高考综合改革实施方案
  4. 数据引擎-阿里开源引擎OceanBase
  5. IT人的英语歌单:没有Bug的日子充满了Sunshine
  6. DaVinci Resolve Guru: Color Correcting Log Raw and Flat Footage DaVinci Resolve大师课程:颜色校正日志原始和平面素材 L
  7. 南大通用数据库-Gbase-8a-学习-15-Gbase8a通过Dblink访问Gbase8a(95->86)
  8. 91助手之联系人获取
  9. 2022第五届上海国际网红品牌博览会
  10. STM32学习笔记7(串口通信)