JS基础第二节

一、数组

数组是一个有序列表,所以有下标.

并且数组在js中可以存在任意类型的数据.并且同一个数组中可以存放不同的类型.

获取数组容量可以用length.

1.创建数组

使用Array数组对象来创建数组

定义一个空数组

var ? ?arr1=newArray();

定义一个数组length是20,并且每个元素都是未定义

var ? ?arr2=newArray(20);

多个值代表数组内部元素,而上面的那种写法一个值代表容量

var ?arr3=newArray(1,2,3);

使用字面量(语法糖,笑笑语法),来创建数组

var ? arr5=[];

var ? arr6=[1,2,3,4];

在使用字面量创建数组时,一个值不再代表容量,代表就是一个值。区别于用Array对象创建的数组。

var ? arr7=[20];

怎么使用数组:

访问数组元素 语法格式:数组名[下标]

下标从0开始数,到数组容量减去1。不允许越界访问

在很多应用中,不管是遍历数组还是为数组赋值,都离不开for循环。

var ? arr2=[];//创建一个空数组

for(var ? i=0; i<20; i++) {//循环赋值

arr2[i]=parseInt(Math.random()*(40-20+1)+20)}

2.Math数学对象

Math对象, 针对于数字。

Math随机函数:Math.random() [0,1)之间的浮点数

如果想得到[a,b]的随机整数

var ? randomNum = parseInt(Math.random() * (b - a + 1) + a); ? //如果不加1,就不能获取到最大值

取最大值

var ? a=Math.max(1,5,7);

取最小值

var ? a=Math.min(1,5,7);

向上取整

var ? num1=Math.ceil(1.1);

向下取整

var ? num2=Math.floor(1.1);

四舍五入

var ? num3=Math.round(2.5);

绝对值

var ? ?num4=Math.abs(-6);

次方

var ? ?num5=Math.pow(5,2);//第一个数是底数第二个数是幂

//平方根,开平方

var ? ?num6=Math.sqrt(4);


3.数组排序

冒泡排序,双层for循环

原理:冒泡排序名称的缘来是根据气泡排序的原理,通过一趟趟的比较,每一趟可以得到当前趟的最大值

比较相邻两个值的大小关系,如果前面的大于后面的,交换位置

外层循环控制比较的趟数,内层循环控制每一趟比较的次数

//定义一个数组

var ?arr=[ ];

for(var ? ?i=0;i<5;i++) {//随机产生一个数组

arr[i]=parseInt(Math.random()*(40-20+1)+20);

}

//从小到大排序,大的在后面,小的在前面(升序)

for(var ? ?i=0;i<arr.length-1;i++) {

for(var ? ? j=0;j<arr.length-i-1;j++) {

//如果前面的大于后面的换位置

if(arr[j]>arr[j+1]) {

var ? ?temp=arr[j];

arr[j]=arr[j+1];

arr[j+1]=temp;

}

}

}

console.log(arr);

4.数组对象

var ? arr=[1,2,3,4,5];

在尾部添加元素,push(),返回值为添加的元素之后的数组容量,不管有没有接收返回值,都将元素添加到数组里面

var b=arr.push(6,7,8,9,12,18);

在头部添加元素,unshift(),返回值为添加的元素之后的数组容量,元素的添加位置在数组头部

var count2=arr.unshift(7);

删除尾部元素,pop(),一次只能删一个,返回值为删除的那个数,并且数组本身最后一个元素也被删除

var ? count3=arr.pop();

删除头部元素,shift(),一次只能删一个,返回值为删除的那个数,并且数组本身第一个元素也被删除

var ? count4=arr.shift();

从指定位置开始删除多少个元素,splice(),返回值为删除的元素组成的数组,返回值是一个数组额!splice既可以进行添加删除的操作,又可以进行替换的操作。splice添加的元素的个数可以不跟删除的元素的个数相同。

var ? count5=arr.splice(1,2);

从下标为1的地方删除0个元素,并且新添加的元素从下标为1,返回值没有任何意义,是一个空数组

var ?count6=arr.splice(1,0,8,9);

数组排序方法,sort(): 方法能实现数组的排序(按照ASCII表的顺序排序),按照ASCII表的顺序排序,只能挨个数字或者字母比较,所以不行??梢杂煤瓿啥允榈纳蚝徒敌?。sort()返回值是一个排序之后的数组。

var ?arr=[12,8,9,5,3,28];

var ? d=arr.sort();

?//console.log(arr.sort())

//console.log(d);

//sort里面封装的有判断语句

function ? sort1(a,b){

return ? ?a-b;

}

console.log(arr.sort(sort1))

数组的拼接,concat(): 方法可以实现两个数组的拼接

var newArr=arr.concat(7,12,19);

var ? newArr2=arr.concat(arr2);

数组元素之间添加分隔符,join(),将数组分割成字符串

var ? arr=[12,8,9];

var ? ?str=arr.join("&");

console.log(str);

5.二维数组

二维数组解决行、列问题,二维数组有行,列概念,二维数组有双下标概念,数组元素是数组

var ? ?var2D=[

[1,2,3],

[4,5,6],

[7,8,9]

];


二、字符串

1.创建字符串

空字符串

var ? str= newString();

创建一个hello world

var ? str= newString("hello world !");

String()将数字转换为字符串

var ? ?str=String(10);

toString()将数字转换为字符串

var ? a=20;

var ? ?str1=a.toString();

2.字符串的操作

charAt():返回字符串的某一位;参数传的值是单个值,数字和字符串都可以

var ?str="hello world";

console.log(str.charAt(6));//w

console.log(str.charAt('6'));//w

search: 查找,返回的是位置,如果找不到返回的是-1。得到的是传入的字符串 在原来的字符串的位置,search传入的都是符合正则验证的字符串

indexOf也是查找,可以传入任何类型的字符串

var ? str="松江区.泗泾镇.九干路丽德创业园";

console.log(str.search("泗泾镇")); ? ? ? ?//4

console.log(str.indexOf("泗泾镇")); ? ? ? //4

console.log(str.search(".")); ? ? ? ? ? ? ? ? ?//0

console.log(str.indexOf(".")); ? ? ? ? ? ? ? ?//3

字符串的截?。簊lice方法,传入两个参数,一个代表start,一个代表end。从start位置开始截取,截取到end位置之前的最后一个字符。截取出来的字符串长度为end-start。如果参数为负数,则将负数加上字符串长度,转换成整数之后再进行截取。如果负数的绝对值大于字符串的长度,start按照0算。如果start大于end将返回空字符串。

var ? str="hello world";

console.log(str.slice(1,7));

console.log(str.slice(-7,7));

substring和slice的区别,substring参数如果为负数,直接变为0,然后运算。substring两个参数不需要保证前面的一定小于后面的,取两者中小的作为start。

console.log(str.substring(-7,7));

console.log(str.substring(7,4));

substr第一个参数代表起始位置,第二个参数代表截取长度。

console.log(str.substr(3,7));

substring 和 slice如果给定一个参数,将从这个参数开始截取到最后

console.log(str.substring(3));

console.log(str.slice(3));

replace 用第二个参数将第一个参数替换掉

var ? str="hello world";

console.log(str.replace("hello","hi"))

split() 方法用于把一个字符串分割成字符串数组,一般和正则一起用。将字符串按照给定的内容精选分割,得到一个数组

console.log(str.split(" "));

空字符串全部分割

console.log(str.split(""));

concat()将一个字符串或多个字符串拼接起来,获得一个新的字符串

+号可以直接拼接,运算符重载

console.log(str.concat("hahaha"));

lastIndexOf()返回最后一个满足条件的下标

indexOf()返回的是第一个满足条件的下标

var ? ? str="hello world hello hello world";

console.log(str.indexOf("hello"));//0

console.log(str.lastIndexOf("hello"));//18


三、Date()日期对象

1.构建日期对象

var ? ?nowDate= new ? ?Date();

console.log(nowDate); ? ? ? ? ?//获取的的是当前时间

console.log(typeof(nowDate)); ? ? //object

2.将日期字符串转换为日期对象

日期对象有两种:

yyy/MM/dd hh:mm:ss

yyy-MM-dd hh:mm:ss,在IE下转换失败

如果字符串yyy/MM/dd里面不给定时间,默认时间00:00:00

如果字符串yyy-MM-dd里面不给定时间,默认时间为当前时区时间

var ? ? ? d= new ? ? Date("2016/11/22 11:52:30");

console.log(d);

var ? ? ? d= new ? ? Date("2016-11-22 11:52:30");

console.log(d);

var ? ? ? d= new ? ? ? ?Date("2016/11/22");

console.log(d);

var ? ? ? d= new ? ? ? ?Date("2016-11-22");

console.log(d);

3.可以直接给定值

可以单独给的年月日 时分秒 毫秒,

月份给值是0~11的,0代表1月,11代表12月

小时 0~23

分钟,秒0~59

毫秒0~999

var ? ? ?d= new ? ? ?Date(1993,0,30);

console.log(d);

var ? ? ?newD= new ? ? ? Date(2017,0,1);

console.log(newD);

4.get方法

var ? ? d= newDate();

year=d.getFullYear();//获取4位数的年份

month=d.getMonth();//获取月份,从0开始,0表示1月

Date=d.getDate();//获取月份中的天数,日期

Day=d.getDay();//获取是周几,从0开始,0是周天

hour=d.getHours();//获取小时

Minutes=d.getMinutes();//获取分钟

second=d.getSeconds();//获取秒

m=d.getMilliseconds();//获取毫秒

time=d.getTime();//获取从1970年1月1日到现在的毫秒数

console.log(year);

console.log(month);

console.log(Date);

console.log(Day);

console.log(hour);

console.log(Minutes);

console.log(second);

console.log(m);

console.log(time);

5.日期对象的设置方法

通过set方法可以将日期对象中的某一个值改掉

var ? myDate= new ? ? ?Date();

myDate.setFullYear(2017);

console.log(myDate);

myDate.setMonth(1);

console.log(myDate);

6.日期对象转换为字符串对象的方法

var ? myDate= new ? ?Date();

console.log(myDate.toString());

console.log(myDate.toLocaleString())

7.日期对象的两个静态方法

快捷获取当前日期和1970.1.1之间 的毫秒数

console.log(Date.now());

快捷获取某一个日期与1970.1.1之间 的毫秒数

console.log(Date.parse("2016/11/22 15:23:00"));


四、函数

定义:函数就是有特定功能的代码段

分类:函数从定义的角度分,分为库函数和自定义函数

库函数:Math.random() ? Array slice() ? ? string substring() ? Date ? ?getTime()......

系统提供的函数远远满足不了我们的需求,所以我们需要自定义函数

函数的结构:定义函数的关键字 function,函数名,参数部分(),没有参数()也不能省略,函数主体部分,大括号内部的内容

function ? ?alertHello() {

alert("hello");

}

在函数中,想要定义一个函数,如果什么是未知的,就将什么声明为参数

使用函数,函数的调用,

1.自定义函数的分类

自定义函数的分类 从两方面考虑:返回值(就是函数的内部返回到外界的结果)和 参数

有参有返,参数与参数之间使用逗号隔开

function ? ?sum(num1,num2) {

//返回外界值,使用关键字return

return ? ? num1+num2;

//return之后的语句都不会执行

num1++;

num2++;

}

//声明一个变量接收返回值

var ? result=sum(10,20);

console.log(result);

function ? sum(num1,num2) {

num1++;

num2++;

return ? ?num1+num2;

}

var ? n1=10,n2=20;

var ? ? ?result=sum(n1, n2);

console.log(result);//32

console.log(n1, n2);//10? ? ? 20 //函数调用过程中,只会发生单纯的值传递,形参会拷贝实参的值

有参数无返回值

function ? printNumber(num) {//定义函数

console.log(num);

}

printNumber(1);//函数调用

无参数有返回值

function ? ?getStuCount() {

return ? 28;

}

var ? stuCount=getStuCount();

console.log(stuCount);

无参数无返回值

function ? ? helloWorld(){

alert("hello world");

}

helloWorld();

调用函数中,为了让函数正确执行,就算没有参数,()也不能省略

2.函数的作用域

var ? ? ? a=10;//全局变量

//函数的作用域

function ? ? ?test() {

var ? ? ? b=10;//局部变量

alert(a++);

}

test();//10

全局变量必须在调用函数的位置之前,才能被使用。定义在函数内部的变量叫局部变量,生命周期为函数的生命周期,当函数执行完之后就会被回收,所以函数外界不能使用函数内部的变量。

独立于函数存在的变量叫做全局变量,当页面关闭时才会被回收。所以说函数内部可以访问外界全局变量,但是必须保证声明必须在使用之前。当出现全局变量与局部变量重名时,就近原则。

全局变量和局部变量只针对于函数,对于for循环不适用。

3.匿名函数

匿名函数就是没有名的函数,可以直接执行,不需要调用

如果想要匿名函数产生函数名,就要定义一个变量来接收,这个变量就是函数名,调用这个变量就可以执行函数。

btn.onclick=function() {

alert("哈哈哈");

}

var ? ? ?fn=function() {//如果匿名函数想要名,

alert("呵呵");

}

fn();

4、函数递归

递归一定要有出口,否则将无限执行 内存崩溃

求5的阶乘

function ? ? fact(num){

if(num==1) {

return ? ?1;

}else{

return ? ?num*fact(num-1);

}

}

var ? ?result=fact(5);

console.log(result);

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容