Javascript备忘复习笔记1
一.字符串操作
1.大小写
var s = "hello";
undefined
g = s.toUpperCase();
"HELLO"
g;
"HELLO"
g.toLowerCase();
"hello"
2.索引/截断
s.indexOf('o');
4
all.js:1 loading comments...
var l = "hello world";
undefined
l.substring(0,5);
"hello"
l.substring(7);
"orld"
二.数组
1.索引/长度
var arr = [1, 2, 3.14, 'Hello', null, true];
undefined
arr.length;
6
arr[2]=99;
99
arr;
[1, 2, 99, "Hello", null, true]
2.切片
arr;
[1, 2, 99, "Hello", null, true]
arr.slice(1,3);
[2, 99]
3.pop/push与shift/unshift(从头删除,从头插入)
arr;
[1, 2, 99, "Hello", null, true]
arr.pop();
true
arr;
[1, 2, 99, "Hello", null]
arr.push(1,"sd");
7
arr;
[1, 2, 99, "Hello", null, 1, "sd"]
arr.unshift('head','sec');
9
arr;
["head", "sec", 1, 2, 99, "Hello", null, 1, "sd"]
arr.shift();
"head"
arr;
["sec", 1, 2, 99, "Hello", null, 1, "sd"]
4.排序/翻转/指定索引删除
var arr = [1, 2, 3.14, 'Hello', null, true];
undefined
arr.sort();
[1, 2, 3.14, "Hello", null, true]
arr.reverse();
[true, null, "Hello", 3.14, 2, 1]
var arr = ['Microsoft', 'Apple', 'Yahoo', 'AOL', 'Excite', 'Oracle'];
undefined
arr.splice(2, 3, 'Google', 'Facebook');
["Yahoo", "AOL", "Excite"]
arr;
["Microsoft", "Apple", "Google", "Facebook", "Oracle"]
arr.splice(2,2);
["Google", "Facebook"]
5.数组的拼接
arr;
["Microsoft", "Apple", "Oracle"]
var lst = ['A','B','C'];
undefined
var lstadd = arr.concat(lst);
undefined
lstadd;
["Microsoft", "Apple", "Oracle", "A", "B", "C"]
lstadd.join('-');
"Microsoft-Apple-Oracle-A-B-C"
6.多维数组
三.对象
var xiaoming = {
name: '小明',
birth: 1990,
school: 'No.1 Middle School',
height: 1.70,
weight: 65,
score: null
};
undefined
xiaoming.name;
"小明"
xiaoming['name'];
"小明"
'name' in xiaoming;
true
xiaoming.hasOwnProperty('name');
true
四.循环
1.数组
var arr = ['Apple', 'Google', 'Microsoft'];
for (var i = 0; i <= arr.length; i++) {
alert(arr[i]);
}
2.列表
var arr = 'sdadda';
for (var i = 0; i <= arr.length; i++) {
alert(arr[i]);
}
3.对象(类似python的dict)
var o = {
name: "jack",
age: 20,
city: 'Beijing'
};
for (var key in o){
alert(o[key]);
}
五.Map/set(Map:类似python的dict)
1.Map取值
var m = new Map([
['Michael', 95], ['Bob', 75], ['Tracy', 85]
]);
alert(m.get('Michael'));
2.Map增/删值
var m = new Map();
m.set('alex',67);
m.set('bob',59);
alert(m.has('bob'));
m.delete('bob');
alert(m.get('alex'));
3.Set(去重,类似python列表的newlst = set(lst))
var s2 = new Set([1, 2, 3]);
undefined
s2;
Set {1, 2, 3}
s2.add(4);
Set {1, 2, 3, 4}
s2.delete(2);
true
s2;
Set {1, 3, 4}
all.js:1 loading comments...
s2.add(4);
Set {1, 3, 4}
六.迭代器(Array、Map和Set都属于iterable类型,用for..of迭代---PS:for..of是对for..in的修复)
1.for..of
var a = ['A','B','C'];
var s = new Set(['A', 'B', 'C']);
var m = new Map([[1,'x'],['name','y'],[3,'z']]); for (var x of a){
alert(x);
}
for (var x of s){
alert(x);
}
for (var x of m){
alert(x[0]+'='+x[1]);
}
2.forEach
//array
var a = ['A', 'B', 'C'];
a.forEach(function (element, index, array) {
// element: 指向当前元素的值
// index: 指向当前索引
// array: 指向Array对象本身
alert(element);
}); //Map
var m = new Map([[1, 'x'], [2, 'y'], [3, 'z']]);
m.forEach(function (value,key,map){
alert(value);
alert(key);
}); //set无索引
var s = new Set(['A', 'B', 'C']);
s.forEach(function (element, set) {
alert(element);
});
Javascript备忘复习笔记1的更多相关文章
- Javascript备忘复习笔记2
一.函数与形参 1.函数 function abs(x) { if (x >= 0) { return x; } else { return -x; } } alert(abs(-10)); 2 ...
- Javascript备忘模式
使用备忘模式,利用了函数的自定义属性,先看一个例子 var test = function (){} test.myAttr = "attr"; 这样,就给test加上了一个自定义 ...
- Javascript备忘
js输出对象类型: Object.prototype.toString.apply(s) 设置单行点击效果: obj.style.background = "#efefef";se ...
- Javascript 备忘
1遍历所有属性 var person={fname:"John",lname:"Doe",age:25}; for (x in person) { txt=tx ...
- javascript 备忘 细节 相关
DOMContentLoaded事件触发时机,即dom tree完成但页面未必渲染完毕. var a = [1,2,3,4]; var length = a.length; alert((leng ...
- JavaScript对象(复习笔记)
js对象 对象构造器 function person(firstname,lastname,age,eyecolor){ this.firstname=firstname; this.lastname ...
- JavaScript基础教程复习笔记
document.write("<h1>这是一个标题</h1>"); 您只能在 HTML 输出中使用 document.write.如果您在文档加载后使用该 ...
- git备忘 & ProGit笔记
git configgit config xxxxx xxxx可以是 --global(使用的是~/.gitconfig) --system(据说在linux下面使用的是/etc/gitcon ...
- [备忘]Asp.net MVC 将服务端Model传递的对象转为客户端javascript对象
<script type="text/javascript"> var jsObject = @Html.Raw(Json.Encode(Model.Objects)) ...
随机推荐
- 导致VC不能释放的几个原因
delegate的属性不是weak NSTimer没有invalidate block中的强引用 调用了performSelector,退出时没有cancelPerformSelectorsWithT ...
- iOS开源项目MobileProject功能点介绍
一:MobileProject简介 MobileProject项目是一个以MVC模式搭建的开源功能集合,基于Objective-C上面进行编写,意在解决新项目对于常见功能模块的重复开发,MobileP ...
- Android Adapter的几个方法
1 ListView是在什么时候设置对Adapter的数据监听的? 在setAdapter(ListAdapter adapter)中,会先取消ListView中原来的mAdapter中的数据监听( ...
- iOS中block的使用、实现底层、循环引用、存储位置
一.整体介绍 定义:C语言的匿名函数,
- C中的流程控制
一. 流程控制 l 顺序结构:默认的流程结构.按照书写顺序执行每一条语句. l 选择结构:对给定的条件进行判断,再根据判断结果来决定执行哪一段代码. l 循环结构:在给定条件成立的情况下,反复执行某一 ...
- 【Android】不依赖焦点和选中的TextView跑马灯【2】
前言 之前有写一篇TextView跑马灯的效果,后来实际项目中有发现新的问题,比如还是无法自动跑,文本超过了显示区域就截取的问题,今天换了一种思路来实现,更简单更好用. 声明 欢迎转载,但请保留文章原 ...
- Sql与MySQL简单入门
作为过来人,给"新司机"一点建议:运维时需要搭建的生产环境,需尽量保持与测试环境一致:但搭建环境时,又苦于找不到合适的版本怎么办?不用怕,我是一个体贴的人,管杀也管埋(该链接为My ...
- GitHub Desktop 桌面工具,离线版本下载(无需考虑网络问题)
http://pan.baidu.com/s/1qYq4X0C GitHub Desktop 桌面工具,离线版本下载 对于网络不好,不稳定,安装多次都不成功的,这是你们的最好的安装方法了.
- WPF学习之路(五) 实例:写字板
写字板实例一 MainWindow.xaml <Window x:Class="Wordpad01.MainWindow" xmlns="http://schema ...
- Tomcat 的使用学习
一.Tomcat服务器端口的配置 Tomcat的所有配置都放在conf文件夹之中,里面的server.xml文件是配置的核心文件. 如果想修改Tomcat服务器的启动端口,则可以在server.xml ...