字符串操作:

//str.length
"micromajor".length // 10 //str.charAt()
"micromajor".charAt(0) // "m"
"micromajor".charAt(100) // "" //str.indexOf()
"micro-major".indexOf("-") // 5
"micro-major-web".indexOf("-") // 5
"micro-major".indexOf("major") // 6
"micromajor".indexOf("-") // -1 //str.search()
"micromajor163".search(/[0-9]/) // 10
"micromajor163".search(/[A-Z]/) // -1 //str.match
"micromajor163".match(/[0-9]/) // ["1"]
"micromajor163".match(/[0-9]/g)// ["1","6","3"]
"micromajor163".match(/[A-Z]/) // null //str.replace(' ',' ');
"micromajor163".replace("163","###") // "micromajor###"
"micromajor163".replace(/[0-9]/,"#") // "micromajor#63"
"micromajor163".replace(/[0-9]/g,"#") // "micromajor###"
"micromajor163".replace(/[0-9]/g,"") // "micromajor" //str.substring
"micromajor".substring(5,7) // "ma"
"micromajor".substring(5) // "major" //str.slice() 可传入负数
"micromajor".slice(5,7) // "ma"
"micromajor".slice(5) // "major"
"micromajor".slice(1,-1) // "icromajo"
"micromajor".slice(-3) // "jor" //str.substr()
"micromajor".substr(5,2) // "ma"
"micromajor".substr(5) // "major" //str.split();
"micro major".split(" ") // ["micro","major"]
"micro major".split(" ",1) // ["micro"]
"micro2major".split(/[0-9]/) // ["micro","major"] //str.toLowerCase();
"MicroMajor".toLowerCase() // "micromajor"
//str.toUpperCase();
"MicroMajor".toUpperCase() // "MICROMAJOR" //字符串拼接
"0571" + "-" + "88888888" // "0571-88888888" //转字符
String(163) // "163"
String(null) // "null" // \转义
"micro\"major" // "micro"major"
"micro\\major" // "micro\major"
"micro\tmajor" // "micro major"

一些正则相关:

var str = 'aaa111bb22c3';
var rex = /[a-z]+([0-9]{3})/; //字符串匹配正则表达式
str.match(rex);
//rex最后不带g,只获取第一个匹配的,且会把字符串中匹配正则表达式中括号内的部分也放到数组中。
// -->['aaa111', '111'];
//带g -->['aaa111']; //测试字符串能否匹配表达式
rex.test(str);// --> true //替换
str.replace(rex,'$1');// --> '111bb22c3'

 数组操作:

//arr.indexOf();
var telephones = [110,120,114];
telephones.indexOf(120); // 1
telephones.indexOf(119); // -1 //arr.forEach(function(item,index,array));
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
var editScore = function(item,index,array){
item.score += 5;
};
students.forEach(editScore); //arr.reverse();
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.reverse();
students[0].score; // 70 //arr.sort(function(a,b));
// function(a,b)会返回一个值,如果是小于0的值,就会将a所对应的元素排在前面。
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
var byScore = function(a,b){
return b.score-a.score;
};
students.sort(byScore); //arr.sort();
var studentNames = ["wq","xl","gp"];
studentNames.sort();
studentNames; // ["gp","wq","xl"] //arr.push();插到最后一个。
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.push({id:4,score:90}); var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.push({id:4,score:90},{id:5,score:60}); //arr.unshift;插到第一个。
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.unshift({id:4,score:90}); //arr.shift();移除第一个并返回移除的值。
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.shift(); // {id:1,score:80} //arr.pop();移除最后一个并返回移除的值。
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.pop(); // {id:3,score:70} //arr.splice(移除的元素的索引号,移除的个数,插入的新元素);
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.splice(1,1,{id:4,score:90}); var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.splice(1,1); var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
students.splice(1,0,{id:4,score:90}); //arr.slice();
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
var newStudents = students.slice(0,2); var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
var newStudents = students.slice(0); //arr.contat();
var students1 = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
var students2 = [
{id:4,score:90},
{id:5,score:60}
];
var students3 = [
{id:6,score:40},
{id:7,score:30}
];
var newStudents = students1.concat(students2,students3); //arr.join();
var emails = ["wq@163.com","gp@163.com","xl@163.com"];
emails.join(";"); // "wq@163.com;gp@163.com;xl@163.com" //arr.forEach();
var scores = [60,70,80,90];
var newScores = [];
var addScore = function(item,index,array){
newScores.push(item+5);
};
scores.forEach(addScore);
newScores; // [65,75,85,95]
console.log(scores.forEach(addScore));
console.log(scores); //arr.map(); 有返回值
var scores = [60,70,80,90];
var addScore = function(item,index,array){
return item+5;
};
scores.map(addScore); // [65,75,85,95] // arr.reduce(function(previousResult,item,index,array),previousResult的初始值);
var students = [
{id:1,score:80},
{id:2,score:50},
{id:3,score:70}
];
var sum = function(previousResult,item,index,array){
console.log(previousResult);
console.log(item);
return previousResult+item.score;
};
students.reduce(sum,0); // 200

  

【前端学习笔记02】JavaScript字符串、数组的一些操作方法的更多相关文章

  1. 前端学习笔记之JavaScript

    JavaScript概述 JavaScript的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中),后将其改名ScriptEase(客 ...

  2. 【前端学习笔记】JavaScript 常用方法兼容性封装

    获取样式函数封装 function getStyle(ele,attr){ if(ele.currentStyle){ return ele.currentStyle[attr]; } else{ r ...

  3. Web前端学习笔记之JavaScript、jQuery、AJAX、JSON的区别

    官网的英文解释: javascript和jQuery有点关系,js是一种脚本语言,主要用于客户端,现在主要用于实现一些网页效果. jquery是js的一个库,你可以认为是对js的补充,提供了很多方便易 ...

  4. 【前端学习笔记】JavaScript 小案例合集

    获取一个0-9的随机数: Math.round(Math.random()*9); 去除数组中重复的元素: var arr=[1,3,5,4,3,3,1,4] function editArr(arr ...

  5. 【前端学习笔记】JavaScript JSON对象相关操作

    //JSON方法 //JSON.parse(); var json = '{"name":"zj","age":23}'; JSON.par ...

  6. RX学习笔记:JavaScript数组操作

    RX学习笔记:JavaScript数组操作 2016-07-03 增删元素 unshift() 在数组开关添加元素 array.unshift("value"); array.un ...

  7. 【前端】Web前端学习笔记【2】

    [2016.02.22至今]的学习笔记. 相关博客: Web前端学习笔记[1] 1. this在 JavaScript 中主要有以下五种使用场景 在全局函数调用中,this 绑定全局对象,浏览器环境全 ...

  8. 【前端】Web前端学习笔记【1】

    ... [2015.12.02-2016.02.22]期间的学习笔记. 相关博客: Web前端学习笔记[2] 1. JS中的: (1)continue 语句 (带有或不带标签引用)只能用在循环中. ( ...

  9. 【学习笔记】JavaScript的基础学习

    [学习笔记]JavaScript的基础学习 一 变量 1 变量命名规则 Camel 标记法 首字母是小写的,接下来的字母都以大写字符开头.例如: var myTestValue = 0, mySeco ...

随机推荐

  1. 20155311 《Java程序设计》实验四 (Android程序设计)实验报告

    20155311 <Java程序设计>实验四 (Android程序设计)实验报告 实验内容 基于Android Studio开发简单的Android应用并部署测试; 了解Android.组 ...

  2. # C语言假期学习笔记——6

    C语言假期学习笔记--6 数组 主要学习了一位数组和二维数组. 数组是一组具有相同类型的变量的集合.C语言程序通过元素的下标来访问数组中的元素.(下标从0开始) 一位数组 类型 数组名[元素个数] 二 ...

  3. 任务队列和异步接口的正确打开方式(.NET Core版本)

    任务队列和异步接口的正确打开方式 什么是异步接口? Asynchronous Operations Certain types of operations might require processi ...

  4. DE1-SOC开发板使用学习

    1. Yocto build utility 工具是什么?Linux Console with framebuffer是什么? 2. 文档里面有几个Linux发布版本的,分别是ubuntu和LXDE版 ...

  5. 一个web应用的诞生(2)--使用模板

    经过了第一章的内容,已经可以做出一些简单的页面,首先用这种方式做一个登录页面,首先要创建一个login的路由方法: @app.route("/login",methods=[&qu ...

  6. 关于C语言中内存的3个问题

    1.程序为什么需要内存? 计算机程序 = 代码 + 结果,从宏观上理解,代码就是动作,而数据被动作加工,最终返回结果.程序是被放在内存中运行的,并且需要内存来存储一些临时变量,因此,对于程序来说,内存 ...

  7. Pycharm主菜单学习

    “工欲善其事,必先利其器”,这话我一直是这么坚信的! 找到一款顺手称心的工具,拥有它,熟练地使用它! Pycharm据说就是使用Python的一款最好的工具—— 于是,开始了第一步的学习----先从熟 ...

  8. javascript 强制转换规则 boolean 布尔值类型

    摘自 <你不知道的Javascript(中卷)> p55 一句话简述, 假值表以外的值均可以认为是真值,部分浏览器可能自定义了假值表以外的假值,并不符合W3C规范,需要特殊对待. 首先也是 ...

  9. python3【基础】-list&tuple

    一.list概述 list (列表)是python中最常用的数据类型之一,通过列表可以对数据实现最方便的存储,修改等操作.在python3中,list支持如下方法: Help on class lis ...

  10. lambda(匿名函数)---基于python

    在学习python的过程中,lambda的语法时常会使人感到困惑,lambda是什么,为什么要使用lambda,是不是必须使用lambda? 下面就上面的问题进行一下解答. 1.lambda是什么? ...