常见的几个js疑难点,match,charAt,charCodeAt,map,search
定义和用法
match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。
该方法类似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。
- 语法
- //匹配字符串,返回指定的值
- stringObject.match(searchvalue)
- //匹配正则,返回指定的值
- stringObject.match(regexp)
使用 match() 来检索一个字符串例子:
- <html>
- <body>
- <script type="text/javascript">
- var str="Hello world!"
- document.write(str.match("world") + "<br />")
- document.write(str.match("World") + "<br />")
- document.write(str.match("worlld") + "<br />")
- document.write(str.match("world!"))
- </script>
- </body>
- </html>
最终出现的结果为,world,null,null,world!
使用 match() 来检索一个正则表达式的匹配例子:
- <html>
- <body>
- <script type="text/javascript">
- var str="1 plus 2 equal 3";
- //这里的正则表达式必须加上g,全局匹配,不然就会匹配一个值即返回
- document.write(str.match(/\d+/g))
- </script>
- </body>
- </html>
通常来说,我们用match用在正则上面比较多,也可以用其来代理indexOf和lastIndexOf来判断字符串里面是否存在此值。
JavaScript search() 方法
定义和用法
search() 方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串,检索到则返回匹配的子串的起始位置,无法检索到值,返回-1。
- 语法
- stringObject.search(regexp)
- //该参数可以是需要在 stringObject 中检索的子串,也可以是需要检索的 RegExp 对象。
- //要执行忽略大小写的检索,请追加标志 i。
复制代码
search() 例子:
- <script type="text/javascript">
- var str="Visit W3School!"
- document.write(str.search(/W3School/))
- </script>
返回索引值为6,search通常与正则配合使用,可以达到indexOf的效果。
JavaScript charAt() 方法
定义和用法
charAt() 方法可返回指定位置的字符。
请注意,JavaScript 并没有一种有别于字符串类型的字符数据类型,所以返回的字符是长度为 1 的字符串。
- 语法
- //返回指定位置的字符串
- stringObject.charAt(index)
chartAt实例:
- <script type="text/javascript">
- var str="Hello world!"
- document.write(str.charAt(1))
- </script>
最终返回结果为:e,通常我们可以通过chartAt来从某个字符串取得具体的字符。
JavaScript charCodeAt() 方法
定义和用法
charCodeAt() 方法可返回指定位置的字符的 Unicode 编码。这个返回值是 0 - 65535 之间的整数。
方法 charCodeAt() 与 charAt() 方法执行的操作相似,只不过前者返回的是位于指定位置的字符的编码,而后者返回的是字符子串。
- 语法
- stringObject.charCodeAt(index)
charCodeAt()实例
注释:字符串中第一个字符的下标是 0。如果 index 是负数,或大于等于字符串的长度,则 charCodeAt() 返回 NaN。
- <script type="text/javascript">
- var str="Hello world!"
- document.write(str.charCodeAt(1))
- //返回H的Unicode 编码101
- </script>
js中Array.prototype.map()方法
定义和用法
map() 方法返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组。
- 语法
- array.map(callback[, thisArg])
- //callback原数组中的元素经过该方法后返回一个新的元素。
- //currentValue,callback 的第一个参数,数组中当前被传递的元素。
- //index,callback 的第二个参数,数组中当前被传递的元素的索引。
- //array,callback 的第三个参数,调用 map 方法的数组。
- //thisArg执行 callback 函数时 this 指向的对象。
map 方法会给原数组中的每个元素都按顺序调用一次 callback 函数。callback 每次执行后的返回值组合起来形成一个新数组。 callback 函数只会在有值的索引上被调用;那些从来没被赋过值或者使用
delete 删除的索引则不会被调用。callback 函数会被自动传入三个参数:数组元素,元素索引,原数组本身。
使用map()的第一个例子:
下面的代码将一个数组中的所有单词转换成对应的复数形式.
- function fuzzyPlural(single) {
- var result = single.replace(/o/g, 'e');
- if( single === 'kangaroo'){
- result += 'se';
- }
- return result;
- }
- var words = ["foot", "goose", "moose", "kangaroo"];
- console.log(words.map(fuzzyPlural));
- //最后结果 ["feet", "geese", "meese", "kangareese"]
求数组中每个元素的平方根例子
- var numbers = [1, 4, 9];
- var roots = numbers.map(Math.sqrt);
- /* roots的值为[1, 2, 3], numbers的值仍为[1, 4, 9] */
在字符串上使用 map 方法
- var map = Array.prototype.map
- var a = map.call("Hello World", function(x) { return x.charCodeAt(0); })
- // a的值为[72, 101, 108, 108, 111, 32, 87, 111, 114, 108, 100]
- <!DOCTYPE HTML>
- <html lang="en-US">
- <head>
- <meta charset="UTF-8">
- <title></title>
- </head>
- <body>
- <script type="text/javascript">
- //var map = Array.prototype.map
- var a = Array.prototype.map.call("Hello World", function(x) { return x.charCodeAt(0); })
- // a的值为[72, 101, 108, 108, 111, 32, 87, 111, 114, 108, 100]
- alert(a);
- </script>
- </body>
- </html>
map兼容旧环境
map 是在最近的 ECMA-262 标准中新添加的方法;所以一些旧版本的浏览器可能没有实现该方法。在那些没有原生支持 map 方法的浏览器中,你可以使用下面的 Javascript 代码来实现它。所使用的
算法正是 ECMA-262,第 5 版规定的。假定Object, TypeError, 和 Array 有他们的原始值。而且 callback.call 的原始值也是 Function.prototype.call。
- // 实现 ECMA-262, Edition 5, 15.4.4.19
- // 参考: http://es5.github.com/#x15.4.4.19
- if (!Array.prototype.map) {
- Array.prototype.map = function(callback, thisArg) {
- var T, A, k;
- if (this == null) {
- throw new TypeError(" this is null or not defined");
- }
- // 1. 将O赋值为调用map方法的数组.
- var O = Object(this);
- // 2.将len赋值为数组O的长度.
- var len = O.length >>> 0;
- // 4.如果callback不是函数,则抛出TypeError异常.
- if ({}.toString.call(callback) != "[object Function]") {
- throw new TypeError(callback + " is not a function");
- }
- // 5. 如果参数thisArg有值,则将T赋值为thisArg;否则T为undefined.
- if (thisArg) {
- T = thisArg;
- }
- // 6. 创建新数组A,长度为原数组O长度len
- A = new Array(len);
- // 7. 将k赋值为0
- k = 0;
- // 8. 当 k < len 时,执行循环.
- while(k < len) {
- var kValue, mappedValue;
- //遍历O,k为原数组索引
- if (k in O) {
- //kValue为索引k对应的值.
- kValue = O[ k ];
- // 执行callback,this指向T,参数有三个.分别是kValue:值,k:索引,O:原数组.
- mappedValue = callback.call(T, kValue, k, O);
- // 返回值添加到新书组A中.
- A[ k ] = mappedValue;
- }
- // k自增1
- k++;
- }
- // 9. 返回新数组A
- return A;
- };
- }
通常生成时间戳的巧妙方法
//第一种方式
function getTimeStamp()
{
var timestamp=new Date().getTime();
var timestampstring = timestamp.toString();//一定要转换字符串
oldTimeStamp = timestampstring;
return timestampstring;
} 第二种方式
new Date().toString() //同样可以达到效果,更简洁
如何使用md5加密方法:
引用google,md5加密的库文件:http://crypto-js.googlecode.com/svn/tags/3.1.2/build/rollups/md5.js
其实蛮简单的,里面CryptoJS.SHA1(),直接引用加密即可,举个栗子:
//就这样直接调用就可以了
var keyvaluestring = "ddddd";
sign = CryptoJS.SHA1(keyvaluestring).toString();
常见的几个js疑难点,match,charAt,charCodeAt,map,search的更多相关文章
- 说说常见的几个js疑难点
JavaScript match() 方法 定义和使用方法 match() 方法可在字符串内检索指定的值,或找到一个或多个正則表達式的匹配. 该方法类似 indexOf() 和 lastIndexOf ...
- JS疑难点和GC原理
js解析与序列化json数据(一)json.stringify()的基本用法: 对象有两个方法:stringify()和parse().在最简单的情况下,这两个方法分别用于把JavaScript对象序 ...
- 常见排序算法(JS版)
常见排序算法(JS版)包括: 内置排序,冒泡排序,选择排序,插入排序,希尔排序,快速排序(递归 & 堆栈),归并排序,堆排序,以及分析每种排序算法的执行时间. index.html <! ...
- js 定义像java一样的map方便取值【转】
js 定义像java一样的map方便取值. 百度有位大神说"js对象本身就是一种Map结构",这真是一段让人欢天喜地的代码. <script> //定义一个全局map ...
- python爬虫笔记之re.match匹配,与search、findall区别
为什么re.match匹配不到?re.match匹配规则怎样?(捕一下seo) re.match(pattern, string[, flags]) pattern为匹配规则,即输入正则表达式. st ...
- finereport---FineReport入门常见疑难点
一.入门介绍 二.入门需知 注意:开发人员可以设置DEBUG级别,有助于测试 三.数据准备 数据集sql中可以使用参数宏${}动态地生成过滤条件,${}中的语句在FineReport报表中执行,将${ ...
- 常见开发需求之js处理url汉字编码中的乱码
需求及解决 两个页面传值的需求是很常见的,angular中有很多常见的方法用于传值,而且都不会受到字符编码的影响,而采用传统的url中拼字符串进行传值的操作,如果拼串中涉及到中文字符,我们就要考 ...
- 常见排序算法基于JS的实现
一:冒泡排序 1. 原理 a. 从头开始比较相邻的两个待排序元素,如果前面元素大于后面元素,就将二个元素位置互换 b. 这样对序列的第0个元素到n-1个元素进行一次遍历后,最大的一个元素就“沉”到序列 ...
- JS中的match和test正则表达式验证密码或用户名的一种规则
match语法:字符串.match(正则表达式)有符合的:返回符合的数组无符合的:返回null test语法:正则表达式.test(字符串)有符合的:返回true无符合的 :返回false 该文的密码 ...
随机推荐
- vue加百度统计代码(亲测有效)
申请百度统计后,会得到一段JS代码,需要插入到每个网页中去,在Vue.js项目首先想到的可能就是,把统计代码插入到index.html入口文件中,这样就全局插入,每个页面就都有了;这样做就涉及到一个问 ...
- ava中有三种移位运算符
转自:http://www.cnblogs.com/hongten/p/hongten_java_yiweiyunsuangfu.html << : 左移运算符,num ...
- 【转】Java中的多线程学习大总结
多线程作为Java中很重要的一个知识点,在此还是有必要总结一下的. 一.线程的生命周期及五种基本状态 关于Java中线程的生命周期,首先看一下下面这张较为经典的图: 上图中基本上囊括了Java中多线程 ...
- 简单了解一下什么是Django或者说Django是做什么的?
Django是什么? Django是一个基于Python的Web应用框架.它与Python的另外一个Web 框架 Flask最大的区别是,它奉行 “包含一切” 的哲学.该理念即为:创建 Web 应用所 ...
- Python下字符画(ascii art)生成
之前在b站上看到有人用C写了个脚本把妹抖龙op转换成字符画的形式输出了,感觉比较好玩在下就用python也写了一遍(主要是因为python比较简单好用).这里就这里就不介绍字符画了,因为能搜到这个的肯 ...
- 用plsql 导入导出oracle表结构数据
一.导出 (1)导出数据 进入pl/sql,"工具"---->"Export Tables...",然后在弹出的对话框中选择要导出的表,最后点击" ...
- linux中显示有颜色的字符
https://blog.csdn.net/weixin_42867972/article/details/81700469 # 设置命令提示符 PS1="\033[33;1m[\033[3 ...
- linux 中搜索命令的对比
1.find find是最常用和最强大的查找命令.它能做到实时查找,精确查找,但速度慢. find的使用格式如下: #find [指定目录] [指定条件] [指定动作] 指定目录:是指所要搜索的目录和 ...
- 阿里云被挖矿使用,导致cpu长期处于100%,ddgs进程,xWx3T进程,关于redis密码
1.使用top命令,查看到一个叫xWx3T的进程cpu占用99.8%,由于我的阿里云是单核的,所以最高只能100%. 把它用kill命令杀死后,过一会儿又启动了,又占用100%. 使用ps -ef可以 ...
- [scala] scala 集合(⑧)
1.List 基础操作 2.Set 基础操作 3. TreeSet 排序Set 4. 拉链操作 5. 流 import scala.collection.immutable.TreeSet impor ...