常见的几个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 该文的密码 ...
随机推荐
- python-反射、新式类与经典类搜索的优先级
preface include: getattr setattr delattr hasattr class webserver(object): def __init__(self,num): se ...
- centos7 Minimal安装没有ifconfig
centos7 Minimal 安装后 ip addr 系统的网卡没有分配IP地址 网卡为ens33 cd /etc/sysconfig/network-scripts vi ifcfg-ens33 ...
- 【QT】error: Failed to retrieve MSVC Environment from "\VC\vcvarsall.bat":
安装QT后直接打开,报错. 需要删mysql环境变量. error: Failed to retrieve MSVC Environment from "D:\Englishpath\VS2 ...
- 【转载】高可用的MongoDB集群详解
1.序言 MongoDB 是一个可扩展的高性能,开源,模式自由,面向文档的数据库. 它使用 C++编写.MongoDB 包含一下特点: l 面向集合的存储:适合存储对象及JSON形式的数据. l ...
- Ckeditor的JS的加载和取值和赋值方法
Ckeditor 就是原来的Fckeditor. JS加载: $(function() { CKEDITOR.replace('FContent'); //FContent:这个对应文本域 }); J ...
- Python中的and/or
在Python中,可以通过and,or和not进行逻辑运算,下面就来看看and和or的简单介绍. 逻辑与-and 对于包含and运算的表达式,Python解释器将从左到右扫描,返回第一个为假的表达式值 ...
- ASP.NET MVC 4 (四) 控制器扩展
MVC的标准流程是请求传递给控制器,由控制器action方法操作数据模型,最后交由视图渲染输出,这里忽略了两个细节,就是MVC是如何创建相应控制器实例,又是如何调用控制器action方法的,这就必须讲 ...
- [AX]AX2012 R2 HR Jobs, Positions, Department和Workers
部门.作业(Job的官方翻译)和位置(Position的官方翻译)是AX人力资源管理的基本组织元素,Job和Position在AX有的地方又称作工作和职位,其实这个翻译更为恰当. Job定义的是一个工 ...
- 高德地图api比例尺
20-10m-(19=<zoom<20) 19-10m-(19=<zoom<20) 18-25m-(18=<zoom<19) 17-50m-(17=<zoom ...
- 【安全开发】Android安全编码规范
申明:本文非笔者原创,原文转载自:https://github.com/SecurityPaper/SecurityPaper-web/blob/master/_posts/2.SDL%E8%A7%8 ...