1. String:

切割: 将一个字符串,按指定分隔符,切割为多段子字符串

简单切割: 切割符是固定的

var arr=str.split("切割符")

强调: 切割后的结果中,不包含切割符

复杂切割: 切割符是变化的

var arr=str.split(/正则/)

2. RegExp:

什么是: 封装一条正则表达式,并提供使用正则进行验证和查找的API

何时: 只要在程序中存储一条正则,并使用正则进行验证和查找

如何:

创建: 2种:

1. 如果正则表达式是固定不变的: 用//

var reg=/正则/ig

2. 如果正则表达式是动态变化的:

var reg=new RegExp("正则表达式", "ig")

API:

验证字符串的格式是否符合要求:

var bool=reg.test(str)

用reg检查 str 是否符合格式要求

返回bool:

问题: 默认,只要str中部分内容满足reg要求,就返回true。

解决: 凡是验证,必须前加^,后加$

即查找所有关键词的内容,又查找关键词的位置

var arr=reg.exec(str)

在str中查找下一个reg匹配的关键词的位置和内容

返回: arr的内容和match不加g时返回的arr结构一样

[0: 关键词, index: 位置]

强调: exec要想找所有,也必须加g

3. Math:

什么是: 保存所有数学计算的函数和常量的对象

何时: 只要执行算术计算时,都用Math

如何:

强调: Math不能new!所有的API,都用大写Math直接调用

API:

1. 取整:

上取整: Math.ceil(num)

下取整: Math.floor(num) 不识别单位,无法转换

parseInt(str) 可去掉数字后非数字的单位

四舍五入: Math.round(num)

缺: 只能取整

优: 返回number类型,可直接参与计算

num.toFixed(d)

优: 可灵活指定小数位数

缺: 返回字符串,无法参数+运算

2. 乘方和开平方

乘方: Math.pow(底数, 幂)

开平方: Math.sqrt(num)

3. 最大值和最小值:

Math.max(值1, 值2, ....)

Math.min(值1, 值2, ....)

问题: 不支持查找数组中的最大值和最小值

解决: spead:   ...数组

4. 随机数:

Math.random()  生成0~1之间的随机小数

公式: min~max之间取随机

parseInt(Math.randon()*(max-min+1)+min)

5. 计算角度:

反三角函数: Math.atan(对/临)

问题: 只能计算正负90度内的角度变化,无法区分象限

解决: Math.atan2(对, 临);

4. Date:

什么是: 封装一个时间,并提供操作时间的API

何时: 只要在程序中保存时间或操作时间

如何:

创建: 4种:

1. 创建日期对象,自动获得当前系统时间

var now=new Date()

强调: 只能拿到客户端系统时间

2. 创建日期对象,保存一个自定义时间

var birth=new Date("1993/12/26")

3. 将ms转化为日期对象:

为什么: 数据库中存储时间,都是保存时间的毫秒数

人看不懂

何时: 只要希望在内存中保存数据库中的时间时,都将ms转为date对象

如何: var date=new Date(ms);

4. 复制一个日期对象:

为什么: 日期的计算都是直接修改原日期对象,计算后,无法保留原日期

何时: 只要希望同时保留计算前后的开始和结束时间时,都要先将开始时间复制一个副本,再用副本计算结束时间

如何: var date2=new Date(date1)

JS高级-String- RegExp- Math- Date:的更多相关文章

  1. 总结JS中string、math、array的常用的方法

    JS为每种数据类型都内置很多方法,真的不好记忆,而且有些还容易记混,现整理如下,以便以后查看: 一.String ①charAt()方法用于返回指定索引处的字符.返回的字符是长度为 1 的字符串. 语 ...

  2. js中String 转化为 Date

    <script> var s=["2008-8-1","2009/9/2","10/3/2010"]; for(var i=0; ...

  3. Js高级 部分内容 面向对象

    1.单列模式 2.工厂模式 3.构造函数 (1)类 js天生自带的类 Object基类 Function  Array  String  Number  Math Date Boolean Regex ...

  4. JS内置对象-String对象、Date日期对象、Array数组对象、Math对象

    一.JavaScript中的所有事物都是对象:字符串.数组.数值.函数... 1.每个对象带有属性和方法 JavaScript允许自定义对象 2.自定义对象 a.定义并创建对象实例 b.使用函数来定义 ...

  5. JS中String类型转换Date类型 并 计算时间差

    JS中String类型转换Date类型 1.比较常用的方法,但繁琐,参考如下:主要使用Date的构造方法:Date(int year , int month , int day)<script& ...

  6. JS Math&Date的方法 (上)

    数学对象&时间对象 本篇文章主要介绍Math 和 Date  的常用方法! 一 :Math & Date         Math 数学对象 - 处理数学计算和数学类          ...

  7. JS高级学习路线——面向对象进阶

    构造函数进阶 使用构造函数创建对象 用于创建对象 其除了是一个函数之外,我们又称之为构造对象的函数 - 简称构造函数 function Product(name,description){ //属性 ...

  8. JS高级- OOP-ES5

    1. OOP 面向对象三大特点: 封装,继承,多态 封装: 问题: 构造函数可重用代码和结构定义,但无法节约内存 为什么: 放在构造函数内的方法定义,每new一次,都会反复创建副本——浪费内存 解决: ...

  9. Ext.js高级组件

    第二章:Ext.js高级组件 grid组件 普通方式 表格面板类Ext.grid.Panel xtype(别名):gridpanel.grid title标题.renderTo渲染至.width宽.h ...

  10. 读JS高级——第五章-引用类型 _记录

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

随机推荐

  1. 由于html元素加载导致的问题

    js中要求执行的事件是在完全加载完,但由于本地环境测试一直没发现出问题,在上线后由于网络延迟导致元素加载慢,而事件执行完,没达到预期目标. 这时就需要用到属性 readyState readyStat ...

  2. 全国高校绿色计算大赛 预赛第一阶段(C++)第4关:计算日期

    挑战任务 我们吃的食物都有保质期,现在食品监督管理局想要制作一个能准确计算食品过期日期的小程序,需要请你来进行设计. 例如:A食品在2018年1月1日生产,保质期是20天,则它的过期日期在2018年1 ...

  3. 第二章 向量(d3)有序向量:Fibonacci查找

  4. Jenkins-cli基本用法

    基本的格式为 java -jar jenkins-cli.jar [-s JENKINS_URL] command [options][args] 下面具体介绍各个命令的作用及基本使用方法 1.    ...

  5. git 基本操作命令

    1. git status 查看git 状态 2.git init 3.git push -u origin master 提交 4.git remote set "邮箱地址i" ...

  6. PL/SQL Dev连接Oracle弹出空白提示框的解决方法分享

    第一次安装Oracle,装在虚拟机中,用PL/SQL Dev连接远程数据库的时候老是弹出空白提示框,网上找了很久,解决方法也很多,可是就是没法解决我这种情况的. 出现这种问题,解决方法大概有这几种: ...

  7. mac上将代码上传到github

    前言 有时我们会写一些小程序来学习新的知识,但是完事之后过一段时间可能会忘记,最好的办法就是找到原来的代码看一看.现在可以将代码免费托管到一些网站上,其中最著名的非github莫属了, 今天就把这个过 ...

  8. git删除提交历史

    精准入口==>官方文档 Q:我们在提交代码时,把密码或者敏感信息也提交了,怎么办? A:“在本地删除密码或敏感信息后,再push到远程仓库” Q:"但这样删除后,在仓库的commit历 ...

  9. jsplumb踩坑

    一,,关于连线器label 我们全局设置中可以用 getInstance 实例化新对象 也可以通过 importDefaults 实例化新对象 当我想要给连线器上添加标签  每个连线器上的标签都不一样 ...

  10. 移动端meta行大全

    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable= ...