有时候实现一个具体的功能,写了一半发现写不下去导致半途而废,怎么避免这种情况?
我现在的做法都是实现前只有个大概的方向,代码里的细节是边写边想的,实现不实现的了,要在写的时候才知道。但方向错了后面就都做了无用功。
比如下面这个轮播图的功能,有多个轮播页面,每个页面可以放置多个图标。
我的想法可能是这样的,用伪代码表示:
1 、用个数组存储所有的小图标的名称或路径
let iconList = [{"src": "icon1.png"}, {}, ...]
2 、定义一个变量来表示每个轮播页可以放下的小图标的数量
let iconsPerPage = 8;
3 、根据小图标的数量和每页的数量,可以算出需要的轮播页的数量
let pageCount = Math.ceil(iconList.length / 8)
4 、利用循环生成轮播页
for (let i=0; i<pageCount; i++) {
let page = document.createElement("div");
...
}
5 、然后可以在每个轮播页里,循环生成轮播页里的图标
for (let i=0; i<pageCount; i++) {
for (let j=0; j<iconsPerPage; j++) {
...
}
}
想到这里就结束了。细节是在写代码的过程中边写边想的,至于实现不实现的了,要在写的时候才知道。 比如下面这些步骤都是在过程中才想:
计算出当前小图标在数组中的索引
let index = i * iconsPerPage + j
icon.src = iconsList[index].src
在生成轮播页里的图标时,如果索引超出了数组的长度,就跳出循环
if (index >= icons.length) {
break;
}
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.