发表于: 2019-03-29 20:32:37

1 905



今天完成的事情:

今天在做任务的时候发现对jquery还是不够熟悉,于是回过头又开始学jquery,简单的熟悉了下,总的来说jq还是比较简单,主要是用来简化js,当然那些比较复杂的用法我也没涉及到,所以今天的工作流程基本上是先考虑怎么用js做,有个思路了就开始找资料,看怎么用jq实现,跟刚开始用js的时候一样,会容易犯一些基础性的错误,不过最后也慢慢做出来了,不过代码看起来极其丑陋,完全是为了实现功能而拼凑起来的一些乱七八糟的逻辑,等明天把后面一个页面补上后再回过头来一点一点重构吧

1、最开始遇到的问题是关于传参,开始简单的以为能存到一个全局变量里面,然后调用就行了,通过console.log打印出来看了之后发现全局变量倒是可以调用,可是值清空了,然后开始了解到cookie和sessionstorage以及localstroage等方法,这里用到的是sessionstorage:

传参:

sessionStorage.setItem("numberOfPeople",numberOfPeople);
sessionStorage.setItem("numberOfKillPeople",numberOfKillPeople);

获取:

numberOfPeople = sessionStorage.getItem("numberOfPeople");//获取总人数
numberOfKillPeople = sessionStorage.getItem("numberOfKillPeople");//获取杀手人数

还了解到现在甚至可以再客户端创建数据库,不知道这样是不是给了前端更多的可能。

2、上次任务一没用到洗牌算法,这里就用到了,简单来说就是通过依次让每个元素给随机位置的元素调换位置,这样就达到了随机各个位置元素的目的,实现起来也比较简单:

for (var n = 0n < stateArray.length 1n++) {
   m = Math.floor(Math.random()*stateArray.length);
   temp = stateArray[m];
   stateArray[m] = stateArray[n];
   stateArray[n] = temp;
}

这里这段代码没有封装起来,直接写在外面,所以看起来比较杂乱,后面重构就从这里开始

3、在这个任务中页面切换没有采用两个页面切换链接的方式,是直接用display:none让两个部分交替显示来达到切换的目的,这里遇到了一个问题,给一个元素赋值display:block的时候覆盖掉了display:flex,导致元素无法对齐,竟然还想了半天,还去找别的居中方式,最后在外面又套了个盒子就搞定了,果然flex这个东西用久了就不会其他的方法了。

4、随着盒子嵌套越来越多层,class名越来越长了。。。。我决定去找些优秀的代码来参考一下,看下人家是怎么命名和构建自己的元素结构的。


明天计划的事情:

1、明天计划继续做js任务四,然后早日进到6-10。


遇到的问题:

1、除了对jq不是很熟练以外,其他都还好,没有遇到什么问题。


收获:

JS数组定义及详解

1、什么是数组

数组就是一组数据的集合

其表现形式就是内存中的一段连续的内存地址

数组名称其实就是连续内存地址的首地址

 

2、关于js中的数组特点

数组定义时无需指定数据类型

数组定义时可以无需指定数组长度

数组可以存储任何数据类型的数据(比如说一个元素保存整型,一个元素保存字符串型,这个在JS中是可以的)

创建数组的语法:

var arr=[值1,值2,值3];                     //隐式创建

var arr=new Array(值1,值2,值3);      //直接实例化

var array=new Array(size);           //创建数组并指定长度

JS中符号含义:

()表示函数执行

[]表示语法模拟,表示模拟Array类的实例(=new Array())

{}表示语法模拟,表示模拟Object类的实例(=new Object())

//表示语法模拟(正则对象),表示模拟RegExp类的实例(=new RegExp())

复制代码
 1 //方法一 2 var arr1 = [1,3,5,7,9]; 3 document.write(arr1[2] + '<br>'); 4      5 //方法二 6 var arr2 = new Array(2,4,6,8,10); 7 document.write(arr2[3] + '<br>'); 8      9 //方法三10 var arr3 = new Array(3);//固定数组长度为311 arr3[0] = 1;12 arr3[1] = 2;13 arr3[2] = 3;14 document.write(arr3[2] + '<br>');
复制代码

3、关于数组长度

数组对象.length

在js中,每一个数组对象都可以调用length属性,它表示数组对象下共有几个数组元素

示例:

复制代码
1 var row = ['zhangsan','lisi','wangwu'];2 doucument.write('共有'+row.length+'个人<br>');3 4 var length = row.length;//对数组进行遍历5 for (var i=0;i<length;i++){6 doucument.write(row[i]+'<br>');7 }    
复制代码

 

4、for...in语句

 

在js中,数组不是数据类型,数组的数据类型其实就是对象

Js中的For.....in语句可以实现对一个对象的所有属性的遍历

也可以使用for...in语句实现对一个数组的所有元素的遍历

语法:

for( var i in array ){

}

原理:数组中有几个元素,for..in语句就循环执行多少次

每次执行时,将当前数组元素的下标存放到变量i中

1 var row = ['zhangsan','lisi','wangwu','xiaoqiang'];2 3 for (var i in row){4     document.write(i + ':' + row[i] + '<br>');5 }    

 

结果:

  0:zhangsan
  1:lisi
  2:wangwu
  3:xiaoqiang

 

5、文本下标

格式:

arr['key'] = value;

在js中,文本下标的数组元素,不计入数组长度

以文本下标形式添加到数组,实际是以属性形式添加到数组对象中的

复制代码
1 var arr = [1,2,3];2 arr['first'] = 'zhangsan';3 arr['second'] = 'lisi';4 5 document.write(arr.length + '<br>');6 document.write(arr.first + '<br>');7 document.write(arr.second + '<br>');
复制代码

结果:

  3
  zhangsan
  lisi

遍历带有文本下标的数组:

复制代码
1 var arr = [1,2,3];2 arr['first'] = 'zhangsan';3 arr['second'] = 'lisi';4 5 for(var i in arr){6     document.write(i + ':' + arr[i] + '<br>');7 }
复制代码

结果:

  0:1
  1:2
  2:3
  first:zhangsan
  second:lisi

 

6、多维数组

复制代码
 1 var arr = [ 2         [10,'zhangsan','male'], 3         [11,'lisi','female'], 4         [12,'wangwu','male'] 5     ]; 6 for (var i in arr){ 7     for(var j in arr[i]){ 8         document.write(arr[i][j]); 9     }10     document.write('<br>');11 }
复制代码






返回列表 返回列表
评论

    分享到