1.Math对象
作用:用于执行数学任务,把Math作为对象就可以调用其方法和属性.
eg:    typeof Math);
2.Math属性
    PI:圆周率(约等于 3.1415926);
eg:    console.log(Math.PI);
3.Math方法
    Math.round()四舍五入
    Math.floor()向下取整
    Math.ceil()向上取整
    Math.max()取最大值
    Math.min()取最小值
    Math.abs()取绝对值
    Math.pow(x,y)取x的y次方
    Math.sqrt()开平方
    Math.random()取 0-1之间的随机数不包括1
a)随机数扩展一:
0 - 100(包含)之间的随机值.
    console.log(Math.round(Math.random()*100));
0 - 99(包含)之间的随机值.
    console.log(Math.floor(Math.random()*100));
1 - 100(包含)之间的随机值.
    console.log(Math.ceil(Math.random()*100));
100 - 1000(包含)之间的随机值.
    console.log(Math.round(Math.random()*(1000 - 100) + 100));
解析:Math.random() 0-1
    Math.round(Math.random()) 0-1包含1
    Math.round(Math.random()*900) 0-900;
    Math.round(Math.random()*900 +100) 100-1000;
求两个值之间的随机数封装成一个方法
    function numRandom(x,y){
    console.log(Math.round(Math.random()*(y-x)+x));
    }
4.勾股定理
eg:    function(a,b){
    var c = Math.sqrt(Math.pow(a,2)+Math.pow(b,2));
    console.log(c);
}
function(a,b);
5进制的转换
    console.log((153).toString(16));result 99  转换为16进制
    console.log((153).toString(8)); result 231 转换为8进制
6.创建日期对象
var oDate = new Date();输出的顺序为:week month date hours:minutes:second GMT+0800(中国标准时间);
注:可以自定义输出的日期的格式输出结果为对象中的字符串,
eg:    可以传入的参数格式为:“时:分:秒 月/日/年”、“月/日/年 时:分:秒”、“年/月/日”等字符串。年,月,日,时,分,秒。月是从0开始算的
    var oDate = new Date(12:12:12 11/12/2018);
    var oDate = new Date(11/12/2018 12:12:12);
    var oDate = new Date(2018/11/12);
    var oDate = new Date(2018,11,12,12,12,12);
7.时间戳
概念:从1970年0月0日0时0分0秒开始计算到某一刻时间的总毫秒数.
8.获取日期的方法
eg:    var oDate = new Date();获取日期对象
    console.log(oDate.getFullYear());获取oDate对象的    年份
    console.log(oDate.getMonth());获取oDate对象的    月份
    console.log(oDate.getDate());获取oDate对象的    日期
    console.log(oDate.getHours());获取oDate对象的    小时
    console.log(oDate.getMinutes());获取oDate对象的 分钟
    console.log(oDate.getSeconds());获取oDate对象的    秒
    console.log(oDate.getMilliseconds());获取oDate对象的    毫秒
    console.log(oDate.getTime());获取oDate对象的    时间戳 共13位.
    console.log(oDate.getDate());获取oDate对象的    周天 返回的值为0-6;0为周日
9.设置日期的方法
eg:    var oDate = new Date();获取日期对象
    oDate.setFullYear();设置oDate对象的    年份
    oDate.setMonth();设置oDate对象的    月份
    oDate.setDate();设置oDate对象的    日期
    oDate.setHours();设置oDate对象的    小时
    oDate.setMinutes();设置oDate对象的 分钟
    oDate.setSeconds();设置oDate对象的    秒
    oDate.setMilliseconds();设置oDate对象的    毫秒
    oDate.setTime();设置oDate对象的    时间戳 共13位.
    oDate.setDate();设置oDate对象的    周天 返回的值为0-6;0为周日
10.常用日期工具
a)将日期格式化成字符串  字符串的格式为  YYYY-MM-DD HH:II:SS
    function formatDateToString(){
        // 先获取对象日期
        var oDate = new Date();
        // 从该对象中分别拿出所需要的    年,月日,时,分,秒 并放到一个变量中存储起来
        var year = oDate.getFullYear();
        var month = oDate.getMonth()+1;
        var date = oDate.getDate();
        var hours = oDate.getHours();
        var minutes = oDate.getMinutes();
        var seconds = oDate.getSeconds();
        return year + "-" + month + "-" + date + " " + hours + ":" + minutes + ":" + seconds;
    }
    console.log(formatDateToString());//调用方法。输出结果为计算机当前时间,格式为2018-01-24 18:01:43;
b)将日期格式的字符串转换成对象    格式为 YYYY-MM-DD HH:II:SS
function formatStringToDate(str){
        //字符串的分割,丢弃所分割的字符并产生的字符串
        var oDate =str.split(" ");//[2018-01-24,15:01:43]
        //将日期分割成年份和时间两部分
        var left = oDate[0];//[2018-01-24]
        var right = oDate[1];//[18:01:43]
        left = left.split("-");//[2018,01,24]
        right = right.split(":");//[18,01,43]
        return new Date(left[0],left[1]-1,left[2],right[0],right[1],right[2]);
    }
    console.log(formatStringToDate('2018-01-24 18:01:43'));//此时输入的月份是比输出的月份大一的
c)将字符串格式的日期转换成毫秒
    function formatStringToMilli(str){
         //因为日期的方法中有直接转换为毫秒的方法 oDate.getTime();所以现将字符串格式的日期转换为对象
         var oDate = formatStringToDate(str); // 调用前面所封装的将字符串转换为对象的方法
         return oDate.getTime();
    }
    console.log(formatStringToMilli('2018-01-24 18:01:43'));
d)计算两个日期的差值.
    function diffDate(str1,str2){
         var
             oDate1 = formatStringToDate(str1),
             oDate2 = formatStringToDate(str2);
         return oDate2.getTime() - oDate1.getTime();
     }
     console.log(diffDate('2018-01-24 18:01:43','2018-01-24 18:01:44'));
//解析思路:先用已经封装的方法b)转换为对象.然后使用日期自身的time方法,转换为毫秒后,用第二个所给的日期减去第一个所给的日期得出毫秒差
11.延时器
a)语法:var timer = setTimeout(function(){},time);
eg:    setTimeout(function(){
        console.log("你好,狗子,你还是变了");
    },2000); //这里的2000是毫秒, 1s =1000ms;
b)清除延迟器
语法:clearTimeout(function(){},time);
eg:    var timer = setTimeout(function(){
    console.log('你好,猴子,你还是变了');
},3000);
    clearTimeout(function(){
        clearTimeout(timer);    
    },2000);
12.计时器
语法:var timer = setInterval(function(){},time);
eg:    var num = 10;
    var timer = setInterval(function(){
        if(num == 0){
            clearInterval(timer);//当计时到0是清除计时
        }
        console.log(num--);
    },1000);// 这里的1000毫秒是每隔一秒计时器执行一次
 

(九)jsMath的更多相关文章

  1. 如何一步一步用DDD设计一个电商网站(九)—— 小心陷入值对象持久化的坑

    阅读目录 前言 场景1的思考 场景2的思考 避坑方式 实践 结语 一.前言 在上一篇中(如何一步一步用DDD设计一个电商网站(八)—— 会员价的集成),有一行注释的代码: public interfa ...

  2. 谈谈一些有趣的CSS题目(九)-- 巧妙的实现 CSS 斜线

    开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题 ...

  3. CRL快速开发框架系列教程九(导入/导出数据)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  4. Python(九)Tornado web 框架

    一.简介 Tornado 是 FriendFeed 使用的可扩展的非阻塞式 web 服务器及其相关工具的开源版本.这个 Web 框架看起来有些像web.py 或者 Google 的 webapp,不过 ...

  5. 我的MYSQL学习心得(九) 索引

    我的MYSQL学习心得(九) 索引 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类 ...

  6. 【Oracle 集群】Linux下Oracle RAC集群搭建之基本测试与使用(九)

    Oracle 11G RAC数据库安装(九) 概述:写下本文档的初衷和动力,来源于上篇的<oracle基本操作手册>.oracle基本操作手册是作者研一假期对oracle基础知识学习的汇总 ...

  7. Jsp的九大对象,七大动作,三大指令

    jsp九大内置对象:1>out 向客户端输出数据,字节流.如out.print(" dgaweyr"); 2>request 接收客户端的http请求.String g ...

  8. 今天我们来认识一下JSP的九大内置对象

    虽然现在基本上我们都是使用SpringMVC+AJAX进行开发了Java Web了,但是还是很有必要了解一下JSP的九大内置对象的.像request.response.session这些对象,即便使用 ...

  9. 浅谈UML的概念和模型之UML九种图

    1.用例图(use case diagrams) [概念]描述用户需求,从用户的角度描述系统的功能 [描述方式]椭圆表示某个用例:人形符号表示角色 [目的]帮组开发团队以一种可视化的方式理解系统的功能 ...

随机推荐

  1. bootstrap datatable 参考文档

    start:http://bootstrap-table.wenzhixin.net.cn/zh-cn/getting-started/ 扩展  http://issues.wenzhixin.net ...

  2. 负载均衡集群ipvsadm命令及基本用法

    ipvsadm是LVS在应用层的管理命令,我们可以通过这个命令去管理LVS的配置.需要使用yum单独安装. 基本用法: ipvsadm COMMAND [protocol] service-addre ...

  3. FutureTask、Fork/Join、 BlockingQueue

    我们之前学习创建线程有Thread和Runnable两种方式,但是两种方式都无法获得执行的结果. 而Callable和Future在任务完成后得到结果.   Future是一个接口,表示一个任务的周期 ...

  4. HTTP与抓包

    HTTP就是超文本传输协议,底层使用socket TCP长连接,基于请求与响应,是同步请求. socket 绝对多数语言都是支持socket的,底层走的是二进制传输. HTTP协议实际上是对Socke ...

  5. EF Code-First 学习之旅 EntityTypeConfiguration<TEntity>

    之前我们配置的实体都都在OnModelCreating方法中,如果有很多实体的话,OnModelCreating方法管理很麻烦 我们可以用单独的类来管理配置,继承EntityTypeConfigura ...

  6. hive 数据清理--数据去重

    hive> select * from (select *,row_number() over (partition by id) num from t_link) t where t.num= ...

  7. LeetCode第[17]题(Java):Letter Combinations of a Phone Number

    题目:最长公共前缀 难度:EASY 题目内容: Given a string containing digits from 2-9 inclusive, return all possible let ...

  8. EditText实现输入表情

    EditText实现输入表情 一.简介 editText是TextView的子类,TextView能用的工具EditText都能用,这里就是editText利用SpannableString的Imag ...

  9. linux find命令使用(转)

    常用命令 find  (目录)   [-type d | f]  (文件夹 | 文件)   -name   (名称,可使用正则表达式) find  /root  -name "*core&q ...

  10. BusyIndicator using MVVM 忙碌状态指示器的的实现

    ViewModel 视图模型 public abstract class ViewModelBase : INotifyPropertyChanged { private bool isbusy; p ...