JavaScript复习笔记——字符串
- //使用new创建字符串对象
- var s1 = new String("hello");
- console.log(typeof s1); //"object"
- //没有new,创建原始类型的字符串
- var s2 = String("hello");
- console.log(typeof s2); //"string"
- //最好是直接使用字面量的方法创建原始类型的字符串:
- var s3 = "hello";
- console.log(typeof s3); //"string"
- //可以调用原始类型的方法和属性:
- console.log(s3.length); //
- //但是不可以往原始类型上面添加属性,即使不提示错误
- s3.name = "fuck";
- console.log(s3.name); //undefined
- var s = "JavaScript";
- console.log(s.length); //
- console.log(s.indexOf("a")); //
- console.log(s.lastIndexOf("a")); //
- console.log(s.charAt(0)); //"J"
- console.log(s.charCodeAt(0)); //
- console.log(s.toLowerCase()); //"javascript"
- console.log(s.toLocaleLowerCase());
- console.log(s.toUpperCase()); //"JAVASCRIPT"
- console.log(s.toLocaleUpperCase()); //
- s.concat(" rulz", "!"); //"JavaScript rulz!"
- var s = "JavaScript";
- s.slice(4, 7); //'Scr'
- s.substring(4, 7); //'Scr'
- s.substr(4, 3); //'Scr'
- console.log("JavaScript".localeCompare("Java")); //
- console.log("JavaScript".localeCompare("JavaScriptz")); //-1
- console.log("JavaScript".localeCompare("JavaScript")); //
- var s = "a,b,c";
- console.log(s.split(",")); //["a", "b", "c"]
- var s = "JavaScript";
- console.log(s.split(/a/)); //["J", "v", "Script"]
- var s = "a ,b ,c ";
- console.log(s.split(",")); //["a ", "b ", "c "]
- var s = "a ,b ,c ";
- console.log(s.split(/\s*,\s*/)) //["a", "b", "c"]
- var s = "JavaScript";
- console.log(s.search(/ava/)); //
- console.log(s.search("Java")); //
- console.log(s.search("JavaEE")); //-1
- console.log(s.search(/Script/)); //
- var s = "JavaScript";
- console.log(s.replace(/a/g, "@")); //"j@v@script"
如果,传递的是一个字符串,其内容会用作一个正则表达式的模式。但是,由于这个例子中,我们无法设置正则表达式模式的修饰符(如g,i,m),因此,只有一次会被替换:
- var s = "JavaScript";
- console.log(s.replace("a", "@")); //"j@vaScript"
这是常见的错误原因之一,即使你只想替换第一次出现,也总是使用正则表达式来搜索,这是好习惯。
- var s = "JavaScript";
- console.log(s.replace(/a/g, "@").replace(/s/gi, "$")); //J@v@$cript
- var ents = "JavaScript".replace(/[a-z]/g, function(match, index, input) {
- //match是a,然后是v,接着是a,以此类推
- //index是match的索引,1, 2, 3, 4, 5, 6...
- //input是"JavaScript"
- return "&#".concat(match.charCodeAt(0), ";");
- });
- console.log(ents); //JavaScript
- var s = "JavaScript";
- console.log(s.match(/[A-Z]/)); //["J"]
- console.log(s.match(/[A-Z]/g)) //["J", "S"]
- console.log("string".match(/[a-z]/)); //["s"]
- console.log(/[a-z]/.exec("string")); //["s"]
"string".match(/[0-9]/); //null
/[0-9]/.exec("string"); //null
JavaScript复习笔记——字符串的更多相关文章
- javascript复习笔记
/* Javascript:用来在页面中编写特效,和HTML.CSS一样都是有浏览器解析 Javascript语言: 一.JS如何运行(javascript,jscript,vbscript,appl ...
- JavaScript复习笔记——数据类型
1.undefined 使用var声明但未对其进行初始化时,这个变量的值就是undefined. 对未被初始化的值使用typeof会返回undefined值,而对未声明的变量执行typeof操作同样也 ...
- JavaScript 重点笔记
JavaScript 重点笔记 ## 数组 // 必须掌握 - arr.length:获取数组元素的长度 - arr.splice(起始位置,长度):从数组中添加或删除元素. - arr.indexO ...
- angular复习笔记4-模板
Angular复习笔记4-模板 简介 模板是一种自定义的标准化页面,通过模板和模板中的数据结合,可以生成各种各样的网页.在Angular中,模板的默认语言是HTML,几乎所有的HTML语法在模板中都是 ...
- Java基础复习笔记系列 七 IO操作
Java基础复习笔记系列之 IO操作 我们说的出入,都是站在程序的角度来说的.FileInputStream是读入数据.?????? 1.流是什么东西? 这章的理解的关键是:形象思维.一个管道插入了一 ...
- Java基础复习笔记系列 五 常用类
Java基础复习笔记系列之 常用类 1.String类介绍. 首先看类所属的包:java.lang.String类. 再看它的构造方法: 2. String s1 = “hello”: String ...
- Java基础复习笔记系列 四 数组
Java基础复习笔记系列之 数组 1.数组初步介绍? Java中的数组是引用类型,不可以直接分配在栈上.不同于C(在Java中,除了基础数据类型外,所有的类型都是引用类型.) Java中的数组在申明时 ...
- JavaScript基础笔记二
一.函数返回值1.什么是函数返回值 函数的执行结果2. 可以没有return // 没有return或者return后面为空则会返回undefined3.一个函数应该只返回一种类型的值 二.可变 ...
- JavaScript基础笔记一
一.真假判断 真的:true.非零数字.非空字符串.非空对象 假的:false.数字零.空字符串.空对象.undefined 例: if(0){ alert(1) }else{ alert(2) } ...
随机推荐
- javascript知识点记录(2)
1.js 异步加载和同步加载 异步加载模式也叫非阻塞模式,浏览器在下载js的同时,同时还会执行后续的页面处理, 在script标签内,用创建一个script元素,并插入到document中,这样就是异 ...
- CSS布局一
CSS布局一 实例一(居中) div#container{ width:960px; height:650px; margin:0 auto; border:1px solid #ccc; /*就是说 ...
- ASINetworkQueue 队列下载
我们通过一个例子介绍一下请求队列使用,我们设计了一个应用,用户点击GO按钮从服务器同时下载两张图片显示在画面中. 我们直接看看主视图控制器ViewController.h代码如下: #import “ ...
- SQL Server Logical/Physical Reads
Summary Info: Logical Reads : Reading Data pages from CachePhysical Reads : Reading Data pages ...
- 使用APICloud写“华为商城”(前端+后端) 无保留提供源码
第一次分享了一个可以算是完整的手机商城项目,之前从别人的源码中得到了许多帮助,现在入门了也希望能帮一下大家. 注: 前端,后端都有 数据用的是APICloud的MCM,所以小心流量. 目前只有Andr ...
- MSYS2 安装和配置
MSYS2 安装和配置 msys2 和 cygwin 类似,提供了一个类 Linux 的 shell 环境和工具链,同时还使用了 arch linux 的 pacman 管理软件包,比 cygwin ...
- RabbitMQ学习总结 第四篇:发布/订阅 Publish/Subscribe
目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...
- Maven 介绍
1.maven的用途maven是一个项目构建和管理的工具,提供了帮助管理 构建.文档.报告.依赖.scms.发布.分发的方法.可以方便的编译代码.进行依赖管理.管理二进制库等等.maven的好处在于可 ...
- 一台电脑多个文件夹安装多个Redis服务
思路: 在弄Mongodb的时候,可以在不同的文件夹下面运行不同的mongodb实例 那么Redis可以吗 现在添加一个Redis文件夹,里面放置redis,修改配置端口为6378 将以前的那个Red ...
- cocos2dx 3.x(获取当前系统时间)
// // MainScene.cpp // helloworld // // Created by apple on 16/10/21. // // #include "MainScene ...