JavaScript 快速应用基本类型window计时器Cookie

Posted 知其黑、受其白

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript 快速应用基本类型window计时器Cookie相关的知识,希望对你有一定的参考价值。

阅读目录

javascript Number 对象

JavaScript 只有一种数字类型,可以使用也可以不使用小数点来书写数字。

JavaScript 数字

JavaScript 数字可以使用也可以不使用小数点来书写:

var pi=3.14;    // 使用小数点
var x=34;       // 不使用小数点

极大或极小的数字可通过科学(指数)计数法来写:

var y=123e5;    // 12300000
var z=123e-5;   // 0.00123

所有 JavaScript 数字均为 64 位

JavaScript 不是类型语言。与许多其他编程语言不同,JavaScript 不定义不同类型的数字,比如整数、短、长、浮点等等。

在JavaScript中,数字不分为整数类型和浮点型类型,所有的数字都是由 浮点型类型。JavaScript 采用 IEEE754 标准定义的 64 位浮点格式表示数字,它能表示最大值 (Number.MAX_VALUE)±1.7976931348623157e+308,最小值 (Number.MIN_VALUE)为 ±5e-324

此格式用 64 位存储数值,其中 0 到 51 存储数字(片段),52 到 62 存储指数,63 位存储符号:

值 (aka Fraction/Mantissa)指数(Exponent)符号(Sign)
52 bits (0 – 51)11 bits (52 – 62)1 bit (63)

精度

整数(不使用小数点或指数计数法)最多为 15 位。

实例:

<button onclick="myFunction()">点我</button>
<p id="demo"></p>

<script>
function myFunction() 
    var x = 999999999999999;
    var y = 9999999999999999;
    document.getElementById("demo").innerhtml = x + "<br>" + y;

</script>


小数的最大位数是 17,但是浮点运算并不总是 100% 准确:

var x;
document.write("<p>仅显示17位: ");

x=12345678901234567890;
document.write(x + "</p>");
document.write("<p>0.2 + 0.1 = ");

x=0.2+0.1;
document.write(x + "</p>");
document.write("<p>可以通过乘以10或除以10来计算: ");

x=(0.2*10+0.1*10)/10;
document.write(x +"</p>");

显示

仅显示17位: 12345678901234567000

0.2 + 0.1 = 0.30000000000000004

可以通过乘以10或除以10来计算: 0.3

二进制、八进制、十六进制

如果前缀为 0,则 JavaScript 会把数值常量解释为八进制数,如果前缀为 0 和 “x”,则解释为十六进制数。

var y = 0377;
var z = 0xFF; 
document.write(y + "<br>");// 255
document.write(z + "<br>");// 255

输出:

255
255

注:绝不要在数字前面写零,除非您需要进行八进制转换。

默认情况下,JavaScript 数字为十进制显示。

但是你可以使用 toString() 方法 输出16进制、8进制、2进制。

var myNumber = 128;
document.write(myNumber + ' 十进制<br>');
document.write(myNumber.toString(16) + ' 十六进制<br>');
document.write(myNumber.toString(8) + ' 八进制<br>');
document.write(myNumber.toString(2) + ' 二进制<br>');

输出:

128 十进制
 80 十六进制
200 八进制
10000000 二进制

无穷大(Infinity)

当数字运算结果超过了 JavaScript 所能表示的数字上限(溢出),结果为一个特殊的无穷大(infinity)值,在 JavaScript 中以 Infinity 表示。

同样地,当负数的值超过了 JavaScript 所能表示的负数范围,结果为负无穷大,在JavaScript 中以 -Infinity 表示。

无穷大值的行为特性和我们所期望的是一致的:基于它们的加、减、乘和除运算结果还是无穷大(当然还保留它们的正负号)。

myNumber=2;

while (myNumber!=Infinity)
    myNumber=myNumber*myNumber;
    document.write(myNumber +'<BR>');

输出结果:

4
16
256
65536
4294967296
18446744073709552000
3.402823669209385e+38
1.157920892373162e+77
1.3407807929942597e+154
Infinity

除以 0 也产生了无限:

var x = 2/0;
var y = -2/0;
document.write(x + "<br>");// Infinity
document.write(y + "<br>");// -Infinity

输出结果:

Infinity
-Infinity

NaN – 非数字值

NaN 属性是代表非数字值的特殊值。
该属性用于指示某个值不是数字。
可以把 Number 对象设置为该值,来指示其不是数字值。

你可以使用 isNaN() 全局函数来判断一个值是否是 NaN 值。

<p>一个数字除以一个字符串结果不是一个数字</p>
<p>一个数字除以一个字符串数字结果是一个数字</p>
<p id="demo"></p>

<script>
var x = 1000 / "Apple";
var y = 1000 / "1000";
document.getElementById("demo").innerHTML = isNaN(x) + "<br>" + isNaN(y);
// true
// false
</script>

输出结果:

一个数字除以一个字符串结果不是一个数字

一个数字除以一个字符串数字结果是一个数字

true
false

除以 0 是无穷大,无穷大是一个数字:

<p id="demo"></p>

<script>
var y = 1000 / 0; // Infinity
document.getElementById("demo").innerHTML = isNaN(y);// false
</script>

数字可以是数字或者对象

数字可以私有数据进行初始化,就像 x = 123;

JavaScript 数字对象初始化数据, var y = new Number(123);

<p id="demo"></p>

<script>
var x = 123;              // x 是一个数字
var y = new Number(123);  // y 是一个对象
var txt = typeof(x) + " " + typeof(y);
document.getElementById("demo").innerHTML=txt; // number object
</script>
<p id="demo"></p>

<script>
var x = 123;              // x 是一个数字
var y = new Number(123);  // y 是一个对象
document.getElementById("demo").innerHTML = x===y; // false
</script>

Number 属性

属性描述
Number.MAX_VALUE最大值
Number.MIN_VALUE最小值
Number.NaN非数字
Number.NEGATIVE_INFINITY负无穷,在溢出时返回
Number.POSITIVE_INFINITY正无穷,在溢出时返回
Number.EPSILON表示 1 和比最接近 1 且大于 1 的最小 Number 之间的差别
Number.MIN_SAFE_INTEGER最小安全整数。
Number.MAX_SAFE_INTEGER最大安全整数。

数字方法

方法描述
Number.parseFloat()将字符串转换成浮点数,和全局方法 parseFloat() 作用一致。
Number.parseInt()将字符串转换成整型数字,和全局方法 parseInt() 作用一致。
Number.isFinite()判断传递的参数是否为有限数字。
Number.isInteger()判断传递的参数是否为整数。
Number.isNaN()判断传递的参数是否为 isNaN()
Number.isSafeInteger()判断传递的参数是否为安全整数。

数字类型原型上的一些方法

方法描述
toExponential()返回一个数字的指数形式的字符串,如:1.23e+2
toFixed()返回指定小数位数的表示形式。

复制var a=123;
b=a.toFixed(2); // b="123.00"
toPrecision()返回一个指定精度的数字。如下例子中,a=123 中,3会由于精度限制消失:

复制var a=123;
b=a.toPrecision(2); // b="1.2e+2"

JavaScript 字符串(String)对象

String 对象用于处理已有的字符块。

JavaScript 字符串

一个字符串用于存储一系列字符就像 “willem”.

一个字符串可以使用单引号或双引号:

var blogname="willem";
var blogname='willem';

你使用位置(索引)可以访问字符串中任何的字符:

var character=blogname[7];

字符串的索引从零开始, 所以字符串第一字符为 [0],第二个字符为 [1],等等。

你可以在字符串中使用引号,如下实例:

var answer="It's alright";
var answer="He is called 'Johnny'";
var answer='He is called "Johnny"';

或者你可以在字符串中使用转义字符 (\\) 使用引号:

var answer='It\\'s alright';
var answer="He is called \\"Johnny\\"";

字符串(String)

字符串(String)使用长度属性 length 来计算字符串的长度:

var txt="Hello World!";
document.write(txt.length+"<br />");

var txt="ABCDEFGHIJKLMNOPQRSTUVWXYZ";
document.write(txt.length+"<br />");

var txt="欢迎来到我的博客!"+"<br />";
document.write(txt.length);

输出结果:

12
26
15

在字符串中查找字符串

字符串使用 indexOf() 来定位字符串中某一个指定的字符首次出现的位置:

var str="Hello world, welcome to the universe.";
var n=str.indexOf("welcome"); // 13

如果没找到对应的字符函数返回 -1

lastIndexOf() 方法在字符串末尾开始查找字符串出现的位置。

内容匹配

match() 函数用来查找字符串中特定的字符,并且如果找到的话,则返回这个字符。

var str="Hello world!";
document.write(str.match("world") + "<br>");
document.write(str.match("World") + "<br>");
document.write(str.match("world!"));

输出结果:

world
null
world!

替换内容

replace() 方法在字符串中用某些字符替换另一些字符。

str="Please visit Microsoft!"
var n=str.replace("Microsoft","willem");
console.log(n); // Please visit willem!

字符串大小写转换

字符串大小写转换使用函数 toUpperCase() / toLowerCase():

var txt="Hello World!";       // String
var txt1=txt.toUpperCase();   // txt1 文本会转换为大写
var txt2=txt.toLowerCase();   // txt2 文本会转换为小写

字符串转为数组

字符串使用 split() 函数转为数组:

txt="a,b,c,d,e"   // String
txt.split(",");   // 使用逗号分隔
txt.split(" ");   // 使用空格分隔
txt.split("|");   // 使用竖线分隔

特殊字符

Javascript 中可以使用反斜线 (\\) 插入特殊符号,如: 撇号,引号等其他特殊符号。

查看如下 JavaScript 代码:

var txt="We are the so-called "Vikings" from the north.";
document.write(txt);

在 JavaScript 中,字符串的开始和停止使用单引号或双引号。
这意味着,上面的字符串将被切成: We are the so-called

解决以上的问题可以使用反斜线来转义引号:

var txt="We are the so-called \\"Vikings\\" from the north.";
document.write(txt);

输出结果:

We are the so-called "Vikings" from the north.

下表列出其他特殊字符,可以使用反斜线转义特殊字符:

代码输出
\\’单引号
\\”双引号
\\\\斜杆
\\n换行
\\r回车
\\ttab
\\b空格
\\f换页

字符串属性和方法

属性:

     length
  prototype
constructor

方法:

    charAt()
charCodeAt()
    concat()
fromCharCode()
     indexOf()
 lastIndexOf()
  match()
replace()
 search()
slice()
split()
   substr()
substring()
toLowerCase()
toUpperCase()
valueOf()

JavaScript Date(日期)对象

创建日期:Date 对象用于处理日期和时间,可以通过 new 关键词来定义 Date 对象。

以下代码定义了名为 myDate 的 Date 对象:

有四种方式初始化日期:

new Date();
new Date(value);
new Date(dateString);
new Date(year, monthIndex [, day [, hours [, minutes [, seconds [, milliseconds]]]]]);

上面的参数大多数都是可选的,在不指定的情况下,默认参数是0。

实例化一个日期的一些例子:

var today = new Date()
var d1 = new Date("December 08, 2021 13:53:00")
var d2 = new Date(21,12,08)
var d3 = new Date(21,12,08,13,33,0)

console.log(today);
console.log(d1);
console.log(d2);
console.log(d3);

输出结果:

Wed May 18 2022 11:44:32 GMT+0800 (中国标准时间)
new.html:19 Wed Dec 08 2021 13:53:00 GMT+0800 (中国标准时间)
new.html:20 Sun Jan 08 1922 00:00:00 GMT+0800 (中国标准时间)
new.html:21 Sun Jan 08 1922 13:33:00 GMT+0800 (中国标准时间)

设置日期

通过使用针对日期对象的方法,我们可以很容易地对日期进行操作。

在下面的例子中,我们为日期对象设置了一个特定的日期 (2010 年 1 月 14 日):

var myDate=new Date();
    myDate.setFullYear(2021,0,14);

console.log(myDate); // Thu Jan 14 2021 11:47:00 GMT+0800 (中国标准时间)

在下面的例子中,我们将日期对象设置为 5 天后的日期:

var myDate=new Date();
    myDate.setDate(myDate.getDate()+5);

注意: 如果增加天数会改变月份或者年份,那么日期对象会自动完成这种转换。

两个日期比较

日期对象也可用于比较两个日期。

下面的代码将当前日期与 2100 年 1 月 14 日做了比较:

var x=new Date();
    x.setFullYear(2100,0,14);
    
var today = new Date();

if (x>today) 
    alert("今天是2100年1月14日之前");
 else 
    alert("今天是2100年1月14日之后");


完整的 Date 对象请参考手册。

JavaScript Array(数组)对象

数组对象的作用是:使用单独的变量名来存储一系列的值。

什么是数组 ?

数组对象是使用单独的变量名来存储一系列的值。

如果你有一组数据(例如:动物名字),存在单独变量如下所示:

var animal1="tiger";
var animal2="lion";
var animal3="monkey";

然而,如果你想从中找出某一种动物?
并且不是3种,而是300种呢?
这将不是一件容易的事!

最好的方法就是用数组。

数组可以用一个变量名存储所有的值,并且可以用变量名访问任何一个值。

数组中的每个元素都有自己的的 ID,以便它可以很容易地被访问到。

创建一个数组

创建一个数组,有三种方法。

下面的代码定义了一个名为 myAniamals 的数组对象:

1、常规方式:

var myAniamals=new Array();
	myAniamals[0]="tiger";      
	myAniamals[1]="lion";
	myAniamals[2]="monkey";

2、简洁方式:

var myAniamals=new Array("tiger","lion","monkey");

3、字面量:

var myAniamals=["tiger","lion","monkey"];

访问数组

通过指定数组名以及索引号码,你可以访问某个特定的元素。

以下实例可以访问 myAniamals 数组的第一个值:

var name=myAniamals[0];

以下实例修改了数组 myAniamals 的第一个元素:

myAniamals[0]="dog";

[0] 是数组的第一个元素。[1] 是数组的第二个元素。

在一个数组中你可以有不同的对象

所有的 JavaScript 变量都是对象。数组元素是对象,函数是对象。

因此,你可以在数组中有不同的变量类型。

你可以在一个数组中包含对象元素、函数、数组:

myArray[0]=Date.now;
myArray[1]=myFunction;
myArray[2]=myAniamals;

数组方法和属性

使用数组对象预定义属性和方法:

var x=myAniamals.length             // myAniamals 中元素的数量
var y=myAniamals.indexOf("tiger")   // "tiger" 值的索引值

完整的数组对象操作参考:https://wgchen.blog.csdn.net/article/details/124150847

创建新方法

原型是 JavaScript 全局构造函数。它可以构建新 Javascript 对象的属性和方法。

<p id="demo">单击按钮创建一个数组,调用 ucase() 方法, 并显示结果。</p>
<button onclick="myFunction()">点我</button>

<script>
    Array.prototype.myUcase = function () 
        for (i = 0; i < this.len

以上是关于JavaScript 快速应用基本类型window计时器Cookie的主要内容,如果未能解决你的问题,请参考以下文章

前端学习笔记TypeScript 快速上手

前端学习笔记TypeScript 快速上手

前端学习笔记TypeScript 快速上手

HaaS轻应用(JavaScript)快速开始 @ N58

JavaScript 基础快速掌握知识点

JavaScript学习--Item4 基本类型和基本包装类型(引用类型)