发表于: 2019-03-25 23:35:17
0 631
今日完成:
今天开始了任务三的,写到一半才想起来用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 = 0; n < stateArray.length - 1; n++) {
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名越来越长了。。。。我决定去找些优秀的代码来参考一下,看下人家是怎么命名和构建自己的元素结构的。
明天计划:
明天上午把小课堂的材料准备好,下午就完成任务三最后一个页面,然后重构下任务三这部分的代码,进入任务四吧。
评论