JS小知识点整合

(一):获取元素

     1:document.getElementById('id名');  
     2:document.getElementsByTagName('获取一组标签');
     3:document.getElementsByClassName('按class名获取');                 
     4:getByClass
     5:document.getElementsByName('按name名获取');  

(二):变量

    1:var name = value;(变量名不可以是数字,不可以使用系统保留名,不可以使用特殊符号);                
    2:var _this = this;
      var $this = this;除外.         

(三):函数

    1:匿名函数--function(){}                
    2:命名函数--function show(){}  
     注:当找不到赋值对象时默认的都是window

(四):流程控制语句几种形式

        1:
            if(条件){
                执行的语句
            }else{
                执行的语句
            }
        2:
            if(条件){
                执行的语句
            }else if(条件){
                执行的语句
            }
        3:
            if(条件){
                执行的语句
            }else if(条件){
                执行的语句
            }else{
                执行的语句
            }
        4:
            if(条件){
                执行的语句
            }
        5:三目 
            条件?语句1:语句2;
        6:并且
            条件 && 语句1;
        7:
            if(条件)
        8:switch判断
            switch(值){
                case :
                语句
                break;
                case :
                语句
                break;
                case :
                语句
                break;
                default:
                break;
            }

(五):循环

        1:
            for(初始值,条件,自增){
                语句
            }
        2:
            for(var name in json){
                语句
            }
        3:
            while(条件){
                要重复做的事情
                改变条件
            }

(六):表单元素和非表单元素的区别

     表单元素的值:用value 获取;
     非表单元素的内容:用 innerHTML 获取

(七):数据的基本类型

        使用 typeof(要测试的数据); 来测试数据类型
                
        1:基本数字类型: number 数字类型   string 字符串类型   boolean(布尔类型  返回 true   false)  undefin 未定义
                        
        2:复合数据类型: object 对象类型
                        
        3:function -- 是一个特殊的,既可以是基本类型,也可以是复合型,但会划分到复合类型里.

类型的前缀:

          类型                前缀                 类型                   实例                                    
         对象                  o                   Object                 oDiv1                                
        数组                   a                  Array                  aItems                                    
        字符串                 s                    String               sUserName                                   
        整数                i                    Integer                 iItemCount                                
       布尔值                 b                     Boolean                 bIsComplete                                 
       浮点数                 f                      Float               fPrice                                 
        函数                  fn                  Function               fnHandler                             
      正则表达式               re                     RegExp                 reEmailCheck                              
      变体变量                 v                     Variant                 vAnything

(八):数据类型的转换(显示型转换或者强制类型转换)

    1:parseInt()  转整数  
    2:parseFloat()  转浮点数   
    3:Number  转数字
    4:NaN  属于数字类型,是一个数字类型,NaN和谁都不想等包括自己.(判断非数字时使用:isNaN());

(九)几种运算符的分类 (运算符:优先级控制要使用小括号 -->())

    1:算术运算符:+ - * / %
    2:赋值运算:= += -= /= *= %=
    3:比较运算:== < <= > >=  != 不等   === 严格的比较,是不是相等,先比较类型    !== 严格的比较,是不是不相等
    4:逻辑运算:与 或 非   || 表示或 只要一个成立,则为真    &&表示并且 全部成立,则为真   !叹号表示取反

(十):什么是真和假

     1:真    true  非空字符串  非零数字  非空对象
     2:假    false  空字符串      数字0    null   undefined   
      (2==true ->false 在计算机里是二进制去运行流程,所以当是二的时候为假).

(十一):关于作用域

     1:全局    是指在所有的函数以外的变量    
     2:局部变量    函数内部的变量(window.onload 下的变量是局部变量)  
     3:闭包  子函数可以使用父函数的变量(在函数上套一层).

(十二):关于js的括号和分号应该什么时候添加?

    1:括号    在定时器里不能使用括号  例如{ setInterval(fn,time);
                     在事件函数里不能使用括号  例如{ oBtn.onclick = fn;}
    2:分号     赋值语句要使用分号  执行语句结束后要使用分号

(十三):随机数:Math.random

            随机数的封装:function rnd(n,m){
                    return Math.floor(Math.random()*(n-m)+m);
                }

(十四):返回值: 函数返回值:return 返回值是指返回给调用者,谁调用就返回给谁.能返回什么,只要你愿意什么都可以返回

(十五):eval 是把字符串变成可执行的语句 *注:具有注入式攻击

(十六):数组的操作

   1)增加  arr.push(数)指放到后面     arr.unshift(数)指放到前面
   2)删除  arr.pop()指删除后面           arr.shift()指删除前面
   3) 删除第几个: arr.splice(开始位置,删除几个[,元素1,元素2])
   4) 转字符串  arr.join(连接的东西) 
   5) 拼接数组 arr. concat(数组的链接) 
   6) 数组排序  arr.sort() 
   7) 反转数组  arr.reverse()

(十七):字符串的操作

   1:查找字符串的位置  str.indexOf('字符串') 指找某个东西在字符串中出现的位置,区分大小写.
   2:查找字符串的位置  str.lastIndexOf(小字符串) 从右往左看,确定一个位置后就不再找,区分大小写.
   3:字符串截取  str.substring(开始位置,结束位置); 
   4:切分字符串  str.split(切的方式) 切分的结果:数组
   5:大小写转换   str.toUpperCase() 把整个字符串转成大写
   6:大小写转换   str.toLowerCase() 把整个字符串转成小写
   7:charAt()

(十八):Math对象

   1:Math.random()  随机数
   2:Math.abs()
   3:Math.max()
   4:Math.min()
   5:Math.pow()
   6:Math.sqrt()
   7:Math.ceil()
   8:Math.floor()
   9:Math.round()

(十九):Date对象:

 var oDate = new Date();  时间
    1:小时:getHours();
    2:分钟:getMinutes();
    3:秒:   getSeconds();
    4:年:   getFullYear()
    5:月:   getMonth()+1 -- 从0月开始
    6:日:   getDate()
    7:星期:getDay() --- 星期日是 0
    8:毫秒: getMilliseconds();
    9:时间戳 getTime() 
    10:setFullYear(年,月,日);
    11:setHours(时,分,秒,毫秒);
    12:setFullYear(年,月-1);
    13:setFullYear(年);
     定时器:
        *原则:定时器要先清除,再打开
                     另一个定时器setTimeout
        setInterval 一直执行,连续不断的
        setTimeout 只执行一次
        setTimeout(函数名,时间) 
        清除:clearTimerout();

(二十):i的问题

  1:使用封闭空间()(i):1)解决了变量冲突的问题    2)i值的问题   3)循环里面加事件,事件里的i不能用
  2:自定义属性   

(二十一):数组:1:arr = []; 2:json = {};

(二十二):DOM的操作:

    1:获取元素--obj.tagName();
    2:父级获取子级 children;
    3:父级元素的子结点数组 childNodes;
    4:首节点:1) oParent.firstChild 2)oParent.children[0];  
            兼容写法:  var oFirst = oParent.fristElementChild || oParent.firstChild;
    5:尾节点  1)oParent.lastChild  2)oParent.children[oParent.children.length -1];
             兼容写法: var oLast = oParent.lastElementChild || oParent.lastChild;
    6:兄弟节点:
                 上一个兄弟节点:var oPrev = obj.previousElementSibling || obj.previousSibling  
         下一个兄弟节点:var oNext = obj.nextElementSibling || obj.nextSibling              
    7:创建元素: document.createElement('标签名');动态创建的元素和原来就存在的元素,没有任何区别
    8:添加元素:document.body.appendChild(obj);
    9:父.appendChild(obj); 表示:添加到父元素的最后面
    10:添加前面:父.insertBefore(obj,谁的前面);
    11:删除元素: 父.removeChild(obj);

(二十三):获取位置

    a:获取可视区宽高
    1:可视区高度:(写法)document.documentElement.clientHeight
    2:可视区的宽度:(写法)document.documentElement.clientWidth
    b:获取盒模型宽高
    1:盒模型高度:offsetHeight
    2:盒模型宽度:offsetWidth
    c:定位父级距离
    1:左:obj.offsetLeft
    2:上:obj.offstTop
    d:绝对位置:getPost
    1:getBoundingClientRect().left
    2:getBoundingClientRect().top
    3:getBoundingClientRect().right
    4:getBoundingClientRect().bottom

(二十四):属性操作:

    getAttribute(属性名)       获取自定义属性
    setAttribute(属性名,值) 设置自定义属性
    removeAttribute(属性名)    删除属性        

(二十五):事件

    1:onclick 点击事件
    2:onmouseover  鼠标移入
    3:onmouseout   鼠标移出
    4:onmousedown  鼠标按下
    5:onmousemove  鼠标移动
    6:onmouseup    鼠标抬起
    7:onmouseenter 鼠标指针移入对象内时触发 
    8:onmouseleave 鼠标指针移出
    9:onmousewheel   鼠标滚轮事件
    10:DOMMouseScroll  兼容火狐的滚轮事件写法
    11:oncontextmenu  鼠标右键菜单事件
    12:ondblclick 鼠标双击事件
    13:onchange  域的内容发生改变
    14:oninput
    15:onblur   失去焦点
    16:obj.focus();强制设置焦点: 
    17:onfocus  获取焦点
    18:obj.blur();强制失去焦点:   
    19:onkeydown 键盘按下时
    20:onkeyup  键盘抬起
    21:onload  载入网页
    22:onerror
    23:onresize 窗口缩小
    24:onscroll 鼠轮滚动执行
    滚动条:
        高: document.documentElement.scrollTop || document.body.scrollTop
        宽:document.documentElement.scrollLeft || document.body.scrollLeft

(二十六)事件对象:ev

    var oEvent = ev || Event;

(二十七)事件流:

    obj.addEventListener('click',fn,false);
        false       事件冒泡
        true        事件捕获(事件下沉)
    只存在高版本浏览器上:obj.attachEvent('onclick',fn);
    面试题:解释一下IE事件流和chrome事件流
        1:IE 只存在事件冒泡
        2:chrome  可以是事件冒泡可以是捕获(true false)
    事件绑定:
    1:obj.addEventListener(事件,函数,是否捕获);
        事件:不能带 on
        兼容性: chrome ff ie9+
    2:obj.attachEvent(事件,函数);
        事件:必须带on
        兼容性:ie 系列
    3:处理兼容性:
        if(obj.addEventListener){
            obj.addEventListener(事件,函数,是否捕获);
        }
        else{
            obj.attachEvent(事件,函数);
            
        事件解绑:
            obj.addEventListener(sEv,fn,false);
                removeEventListener(sEv,fn,false)
            obj.attachEvent(事件,函数);
                obj.detachEvent(事件,函数);                 
        DOMReady();
            1:window.onload所有资源加载完才会加载JS
                html css img video audio flash..  js
            2:DOMReady
                html css js

(二十八)cookie:

    特性:     1:在服务器环境下,跟随服务器发送  
            2:大小只有4K大 
            3:默认会话结束(指关闭浏览器时会话结束)
            4:name=value 成对出现
            5:name不能重复,否则会覆盖
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容