js日志

Javascript学习日志

Writen By CoolGhost,Started With 2016/10

  • 访问JS属性的两种方式
    person.lastName person["lastName"]
  • 如果把值赋给尚未声明的变量,该变量将被自动作为全局变量声明
    • 此处可使用 window.carName
      function myFunction() {
          carName = "Volvo";
      }
      
    • 此处可调用 carName 变量
      function myFunction() {
      carName = "Volvo";
      // 此处可调用 carName 变量
      }
      
  • js中的转义
    \' 单引号\" 双引号\\ 反斜杠\n 换行\r回车\t tab(制表)\b 退格符\f换页符
  • 类型判断
    function User(name , age){
    this.name=name;
    this.age=age;
    }
    var u=new User();
    console.log( 'typeof u  :'+typeof u );  
    //输出object  
    //显然,使用typeof判断复杂类型的对象,就失效了,但使用constructor就可以获取其真实类型
    console.log( 'u.constructor.name  :'+u.constructor.name );   //user
    
  • JS代码块的Break
    cars=["BMW","Volvo","Saab","Ford"];
    list:{
        document.write(cars[0] + "<br>"); 
        document.write(cars[1] + "<br>"); 
        document.write(cars[2] + "<br>"); 
        break list;
        document.write(cars[3] + "<br>"); 
        document.write(cars[4] + "<br>"); 
        document.write(cars[5] + "<br>"); 
    }
    
    以上代码生成了名为list的代码块,并且break进行了跳出,同时continue 具有相同作用,不过只能应用于循环,而通过标签,break能够适用于任何js代码块
  • null和Undefined 区别:
    typeof undefined             // undefined
    typeof null                  // object
    null === undefined           // false
    null == undefined            // true
    
  • JS对象类型:
    • 在 JavaScript 中有 5 种不同的数据类型:
      string,number,boolean,object,function
    • 3 种对象类型:
      Object,Date,Array
    • 2 个不包含任何值的数据类型:
      null,undefined
    • 同时注意typeof方法中:
      NaN 的数据类型是 number
      数组(Array)的数据类型是 object
      日期(Date)的数据类型为 object
      null 的数据类型是 object
      未定义变量的数据类型为 undefined
  • JS的try catch throw
    try{ 
        var x=document.getElementById("demo").value;
        if(x=="")    throw "值为空";
        if(isNaN(x))  throw "不是数字";
        if(x>10)     throw "太大";
        if(x<5)      throw "太小";
    }
    catch(err){
        var y=document.getElementById("mess");
        y.innerHTML="错误:" + err + "。";
    }
    
  • JS的调试方法包括使用debugger,不过使用该方法需要打开浏览器调试工具
  • JS中如果String类型需要分行,要使用\
    var x = "Hello \
    World!";
    
  • 程序块的作用域
    在每个代码块中 JavaScript 不会创建一个新的作用域,一般各个代码块的作用域都是全局的。以下代码的的变量 i 返回 10,而不是 undefined:
    for (var i = 0; i < 10; i++) {
    // some code
    }
    return i;
    
  • JS自调用函数
    以下是,最前最后加括号,还有一些类似的方法,但是这个可读性比较高
    (function() {
        alert(1);
    }());
    
  • JS没有强制要求参数数量和函数调用时的参数数量相同,即:
    x = findMax(1, 123, 500, 115, 44, 88);
    function findMax() {...} 
    

并不会报错。同时JS提供了函数的内置对象arguments,根据这个可以得到相应的参数

  • this的调用
    var myObject = {
        firstName:"John",
        lastName: "Doe",
        fullName: function () {
        return this.firstName + " " + this.lastName;
        }
    }
    myObject.fullName();         // 返回 "John Doe"
    
  • 使用构造函数调用函数
    // 构造函数:
    function myFunction(arg1, arg2) {
        this.firstName = arg1;
        this.lastName  = arg2;
    }
    // This creates a new object
    var x = new myFunction("John","Doe");
    x.firstName;         //John
    
  • JS的Browser对象
    location.hash 设置或返回从井号 (#) 开始的 URL(锚)
    location.host 设置或返回主机名和当前 URL 的端口号
    location.hostname 设置或返回当前 URL 的主机名
    location.href 设置或返回完整的 URL
    location.pathname 设置或返回当前 URL 的路径部分
    location.port 设置或返回当前 URL 的端口号
    location.protocol 设置或返回当前 URL 的协议
    location.search 设置或返回从问号 (?) 开始的 URL(查询部分)
    history.back() 与在浏览器点击后退按钮相同
    history.forward() 与在浏览器中点击按钮向前相同
  • JavaScript 计时事件
    setInterval("javascript function",milliseconds) - 间隔指定的毫秒数不停地执行指定的代码。
    setTimeout("javascript function",milliseconds) - 暂停指定的毫秒数后执行指定的代码
  • jQuery选择器
    • 如果已经是jQuery对象了了,则往下寻找的时候需要使用find()方法,如$("#phase_mx").find("input[name^='mFlt']")
    • jQuery的模糊匹配包括^=$=*=分别对应开始、结束、包含关系。
  • jQuery异步请求
    有三种方式 $.get$.post$.ajax,其中前两者是后者的简单方式,如果需要修改一些参数则要使用$.ajax,
    $.ajax({
        url: "project/import",
        type: "POST",
        async: false,//同步或异步
        data: "test=test",//发送参数
        dataType: "json", //返回类型
        beforSend: function() {
        },
        success: function(msg) {
        },
        error: function() {
        }
    })
    
  • jQuery获取文档内容
    jQuery中有text()和html()方法,和JS的innerTEXT()或innerHTML()类似,并且可以使用回调函数
    $(selector).text(function(index,oldcontent))
    
  • 元素选择器
    利用jQuery选择器选取第几个元素时,不能直接用[]来选择,而是要通过eq来进行选择,如下:
    for (var i = 0; i < $("input[type='text']").length; i++) {
        $("input[type='text'] :eq(" + i + ")").val(i);
    }
    
    而在用dom节点选择的时候则可以利用[]来选择第几个元素,如:
    document.getElementsByName('name')[0].value='changdy'
    
    JS和jQuery的不同一定要注意辨别
  • JS类型转换
    从input中得到的值默认是字符串类型的,如果期望是数字类型比较则有可能得到错误判断。这个时候需要用到类型转换,数字类型的可以使用parseFloat()parseInt()方法。
    另外,JS中也有强制类型转换,比如Boolean(value)、Number(value)、String(value)。具体可以参考:cnblogs
  • jQuery each()方法
    each()方法中的this为dom对象,而不是jQuery对象,转换方法如$(this),如果需要查找子对象则可以使用.find()方法
  • jQuery 发送文件
    当使用Spring MVC接收的时候,参数为@Param("fileName") MultipartFile file
  • 遍历Object对象
    var obj = {a:1 , b:2 , c:3}
    for(var s in obj){
      console.log(s);
      console.log(obj[s]);
    }
    
  • JS中生成和解析JSON
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容

  • 1.几种基本数据类型?复杂数据类型?值类型和引用数据类型?堆栈数据结构? 基本数据类型:Undefined、Nul...
    极乐君阅读 5,512评论 0 106
  • 第一章: JS简介 从当初简单的语言,变成了现在能够处理复杂计算和交互,拥有闭包、匿名函数, 甚至元编程等...
    LaBaby_阅读 1,660评论 0 6
  • 单例模式 适用场景:可能会在场景中使用到对象,但只有一个实例,加载时并不主动创建,需要时才创建 最常见的单例模式,...
    Obeing阅读 2,061评论 1 10
  • 流式布局及动画 被itemSelector选中的元素以及被filter过滤出的元素都会获得流式布局及动画 筛选 排序
    李霖弢阅读 402评论 0 0
  • 传统的并发变成模型通过Mutex/Conditional Variable/Semaphore的设施来控制对共享资...
    驭风万里无垠阅读 908评论 0 0