标签(空格分隔): 廖老师学习笔记 javascript 基本入门

根据廖雪峰老师官网,自己看后的简单笔记 第一小节

基本知识

  1. <script type="text/javascript"></script> 中默认 typeJavascript,所以可以省略type指定为javascript。
  2. 多个alert出现时,alert也依次弹出。eg: alert('啦啦啦'); alert('ba啦啦');alert('baba啦');
  3. =====的差别。A.==比较,它会自动转换数据类型再比较,所以不建议用 == 比较。B.===比较,它不会自动转换数据类型,如果数据类型不一致,返回false。
  4. NaN是一个特殊Number与所有其他值都不相等,包括它自己。 NaN===NaN; //false; isNaN(NaN); //true
  5. null表示”空“; 0时一个数值;‘ ’表示长度为0的字符串。
  6. Javascript的数组包括任意数据类型。 eg:[1,2,3.14,'hello',null,true] 有条件下数组都使用[].
  7. 动态语言:变量本身类型不固定的语言。静态语言:定义变量时必须指定变量类型。
  8. strict 模式: 在Javascript代码的第一行写上: ‘use strict’;
  9. 字符串 ASCII字符可以以\x##形式的十六进制表示,例如: ‘\x41'; //等同于’A'; 字符串是不可变的,如果对索引赋值,不会出错,但没有任何效果。

基本函数

  1. str.toUpperCase(); 把一个字符串全部变为大写。
  2. str.toLowerCase(); 把一个字符串全部变为小写。
  3. str.indexOf('hello');会搜索出字符串出现的索引,没有找到返回-1。
  4. str.substring(0,5);返回索引区间的子串。
  5. 数组中简单函数 arr.indexOf(10);//元素10的索引为2;
  6. arr.slice(0,2);//得到arr[0],arr[1],arr[2],如果只有一个数字则从当前数字到结束。
  7. arr.push('a','b'); //在arr末尾添加‘a','b'; arr.pop(); //删掉arr的最后一个元素。
  8. arr.unshift('a','b');//在头部添加a,b。arr.shift();//删掉arr第一个元素。
  9. arr.sort();//按数组中首字母的ASSII排序。
  10. arr.reverse();//反转数组子集排序;
  11. arr.splice(2,3,'a','b');//splice(开始删除的索引,删除的个数,添加的元素,添加的元素);
  12. arr.concat([1,12,3]);/ arr.concat(1,23,[4,54]) ;//数组链接。
  13. arr.join('-');// 数组内的元素用-连接起来。

对象

  1. 键值 name:'beautiful'形式申明,用隔开。末尾不加
  2. object.prop的形式访问个属性了。访问不存在的属性不报错,而是返回undefined。
  3. prop in object ; 'name' in xiaoming; 检测是否拥有这一属性。自身拥有,而不是继承可以用xiaoming.hasOwnProperty('name');//true or false。
  4. javascript把null、undefined、0、NaN和''视为false,其他值一概视为true。
  5. 循环 for..in.. for(var key in arr) 把一个对所有的属性依次循环 出来。for..in...对array循环得到的是string而不是number。
  6. 过滤继承属性 , 用hasOwnproperty()。 for (var key in arr){ if(arr.hasOwnproperty(key)){ ;

    Map&Set

  7. Map 是一组键值对的结构 。
    var tab=new Map[['lili',98],['tao',89]]; //定义map函数 tab.get('lili'); //98 tab.set('chery',79);//添加 tab.delete('chery'); tab.has('chery');//false
  8. Set是key的集合,但不存储value。由于key不能重复,所以key内没有重复的key。
    var s = new Set([1, 3, 4, '5', 'fast']); var s2 = new Set([1, 2, 3, 3]); // 含1, 2, 3 s.add(45); s.delete(3);
  9. Array,Map,Set都属于iterable类型。
    iterable都可以用for...of循环遍历
    for (var x of a) { //遍历array,Set,Map
    for...of 和for...in区别:for in 存在历史遗留问题,它遍历的为对象属性名称。array也是一个对象,它的每个元素被视为一个属性。但array的length属性却不包括在内。
    var a = ['A', 'B', 'C']; a.name = 'Hello'; for (var x in a) { alert(x); // '0', '1', '2', 'name' }
    最最最好的是使用iterable内置的forEach方法。它接受一个函数,每次迭代就自动的回调该函数。

var arr = ['a', 'l', 'b']; arr.forEach(function (element, index, array) { //element 元素 index 索引 array 字符串 }); var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]); m.forEach(function (value, key, map) { console.log(value, key); //'x','y','z' 1,2,3 });

Javascript 基础知识笔记的更多相关文章

  1. javascript基础知识笔记-自用

    笔记内容根据个人基础知识不足不明白之处做的记录.主要看的:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript 1.变量,变量的名字又叫标识符 ...

  2. JavaScript基础知识笔记

    做前端几年了,一直疏于整理归纳,所以这两天把基础看了一遍,加上使用经验,整理了基础知识中关键技术,旨在系统性的学习和备忘.如果发现错误,请留言提示,谢谢! 重要说明:本文只列举基础知识点,中级和高级内 ...

  3. Javascript基础知识总结一

    Javascript基础知识总结一 <!DOCTYPE html> <html> <head lang="en"> <meta chars ...

  4. 学习javascript基础知识系列第二节 - this用法

    通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...

  5. 学习javascript基础知识系列第三节 - ()()用法

    总目录:通过一段代码学习javascript基础知识系列 注意: 为了便于执行和演示,建议使用chrome浏览器,按F12,然后按Esc(或手动选择)打开console,在console进行执行和演示 ...

  6. JavaScript 基础知识 - BOM篇

    前言 本篇文章是JavaScript基础知识的BOM篇,如果前面的<JavaScript基础知识-DOM篇>看完了,现在就可以学习BOM了. 注意: 所有的案例都在这里链接: 提取密码密码 ...

  7. JS基础知识笔记

    2020-04-15 JS基础知识笔记 // new Boolean()传入的值与if判断一样 var test=new Boolean(); console.log(test); // false ...

  8. Java多线程基础知识笔记(持续更新)

    多线程基础知识笔记 一.线程 1.基本概念 程序(program):是为完成特定任务.用某种语言编写的一组指令的集合.即指一段静态的代码,静态对象. 进程(process):是程序的一次执行过程,或是 ...

  9. (转)JAVA AJAX教程第二章-JAVASCRIPT基础知识

    开篇:JAVASCRIPT是AJAX技术中不可或缺的一部分,所以想学好AJAX以及现在流行的AJAX框架,学好JAVASCRIPT是最重要的.这章我给大家整理了一些JAVASCRIPT的基础知识.常用 ...

随机推荐

  1. POJ2221+模拟

    参考http://blog.sina.com.cn/s/blog_7de5c6210100tm1h.html 其实是水题............ #include<string.h> #i ...

  2. Java金字塔及变形

    Java金字塔 package com.tfj.test; public class JinZiTa { public static void main(String[] args){ int num ...

  3. C#程序中访问配置文件

    在C#编程中,有时候会用到配置文件,那么该如何在程序中获取或修改配置文件中的相关数据呢?下面采用一个简单的C#控制台程序来说明. 新建一个C#控制台程序,打开“解决方案资源管理器”,如下图: 可以看到 ...

  4. MFC CVIew关闭时崩溃

    记得看视频的时候老师说过    创建CView的时候,也就是创建视图的时候,不要使用  Cview      m_view;这种方式 而是使用Cview  *  pView=new   Cview() ...

  5. Android学习之路——简易版微信为例(一)

    这是“Android学习之路”系列文章的开篇,可能会让大家有些失望——这篇文章中我们不介绍简易版微信的实现(不过不是标题党哦,我会在后续博文中一步步实现这个应用程序的).这里主要是和广大园友们聊聊一个 ...

  6. 从头开始编写一个Orchard网上商店模块(4) - 创建ProductPart

    原文地址:http://skywalkersoftwaredevelopment.net/blog/writing-an-orchard-webshop-module-from-scratch-par ...

  7. STL总结之functor

    STL中仿函数是重要的组成部分.所谓的仿函数就是通过重载括号运算符实现的, 如下: STL库中都是泛型仿函数如小于操作: STL中定义了许多有用的操作,如less(小于), less_equal(小于 ...

  8. Linux中的模式转换

    模式转换: 编辑-->输入: i: 在当前光标所在字符的前面,转为输入模式: a: 在当前光标所在字符的后面,转为输入模式: o: 在当前光标所在行的下方,新建一行,并转为输入模式: I:在当前 ...

  9. NOIP2002 均分纸牌

    题一 均分纸牌 (存盘名: NOIPG1) [问题描述] 有 N 堆纸牌,编号分别为 1,2,…, N.每堆上有若干张,但纸牌总数必为 N 的倍数.可以在任一堆上取若于张纸牌,然后移动. 移牌规则为: ...

  10. shell截取字符串方法

    shell中截取字符串的方法有很多中, ${expression}一共有9种使用方法.${parameter:-word}${parameter:=word}${parameter:?word}${p ...