摘要


1.好的代码职责要清晰,javscript不要用来操作样式;

2.API要设计的合理:通用性,适度的抽象(数据抽象,过程抽象),可扩展性;

3.效率问题:用好的、合适的算法(前端程序员要把自己当程序员)。

注:


1.学习视频地址

2.ppt地址

3.个人感想:

  是我hin厉害的师父推荐我看的月影大大的视频,感觉对于我这个小白来说,真的是一遍又一遍的刷新知识面。我觉得像月影大大这种大佬的思路,我接触之后真的是受益匪浅。

  所以我总结出来不仅是自己记笔记,也是想分享给想要成为真正的前端“工程师”的前端er。

  真的很珍惜这种知识面被刷新的感觉——越学习,越感到自己无知,共勉。

目录


1. 问题一:操作DOM

    版本1,初级工程师:

    版本2,中规中矩:

    版本3,专业版:

    操作DOM问题的总结:

2.问题二:API的设计

    版本1: 嵌套setTimeout

    版本2: 数据抽象

    版本3:数据抽象,封装(七八十分)(一定要会)(中规中矩)(项目中用起来不错)

    版本4:过程抽象(版本2和3是数据抽象)

    版本5: 改需求,改时间 的对策

    版本6:(高级程序员写的)

    API设计问题总结:

3.问题三:效率/性能问题

    版本1:两个循环

    版本2:利用数组的排序方法sort,先排序,再遍历

    版本3:空间复杂度换时间复杂度

    效率问题总结

4.总结

正文


1.问题一:操作DOM

做一个列表单选

版本1,初级工程师

优点:

在ul上添加事件句柄,由于事件可以冒泡,在点击事件中筛选event.target来处理就可以

问题:

js负责的是“行为”

在js中定义样式,若需求改动后,会导致不灵活

js:不操作DOM样式,操作DOM状态

版本2,中规中矩:

分清职责:

css中添加样式类

js来操作状态(类属性)

版本3,专业版:

这样实现,充分利用html标准,更具有语义性,灵活

操作DOM问题的总结:

1.写 JavaScript 操作 DOM 要注意什么

不要操作DOM样式

(很多wvvm框架禁止直接在js中操作DOM的原因就是这个,害怕写出版本1那种代码)

2. JavaScript 与 HTML、CSS 的职责如何分离

html负责内容,语义

css负责样式

js负责状态,不负责样式

3. 把复杂性放在哪一头,为什么?

4. 框架?原生?:

框架帮你解决了代码写的不好的问题,一旦用惯了,再换框架,会写出问题很多的代码;

写原生的更能意识到自己的问题;

2.问题二:API的设计

三个状态用红(stop)、绿(pass)、黄(wait)表示

要求用 JavaScript 让三个状态轮流切换

每个状态的停留时间是 2 秒

版本1:

css:

优点:

html,css中把三个状态类”stop”,”wait”,”pass”放在父元素上,然后在css中直接用:nth-child操作父元素的某个子元素,这样灵活性很高

缺点:

如果需求增加到 5 盏、10 盏灯?

const traffic = document.getElementById('traffic');

(function reset(){

  traffic.className = 'wait';

  setTimeout(function(){

      traffic.className = 'stop';

      setTimeout(function(){

        traffic.className = 'pass';

        setTimeout(function(){

          ...

            ...

              ...

                ...

                  setTimeout(reset, 2000)

                ...

              ...

            ...

          ...

        }, 2000)

      }, 2000)

  }, 2000);

})();

过程耦合 + Callback Hell…… 差评!!!:

代码中,三个状态有顺序,必须先1再2再3,过程耦合;

Callback Hell难以维护

版本2:

优点:

把状态抽取出来,通过数组的下标去操作,更改数据很方便

把数据/状态抽象出来

缺点!!:

依赖于外部变量 stateList、currentStateIndex

封装性不好……差评!!

版本3:封装好(七八十分)(一定要会)(中规中矩)

优点:

把currentStateIndex分装进函数,因为使用者使用不到;

把state的数组和dom元素暴露出来,以便更改;

很重要:::::什么该暴露,什么该封装

缺点:

可复用性差,只有当前的能用到

版本4:(过程抽象)(版本2和3是数据抽象)

抽象出来了一个poll 函数是一个高阶函数(偏函数),返回值是function,说明做了一个过程抽象。

它的参数是一系列函数,返回值也是函数,它的功能是按顺序调用参数中的函数。

小王去开门:person类,是数据抽象;开门,开xx,是过程抽象

bind函数也是一个高阶函数(偏函数),它也返回一个函数,

优点:poll函数可复用,很通用。

例如:

版本5:改需求:改时间

版本2.3.4做了抽象反而不能改时间,版本1可以改,要回去???

promise(是es6里面很重要的概念)

不用promise的版本:

版本6:(高级程序员写的)

内部实现很复杂,但是外部API很好用;可以随意向状态列表添加状态,且每个状态里面可以做很多种事情;

API设计问题总结:

1.写原生的js有很多方向可以写,但是用框架类库模式会很固定

2.避免过程耦合,即上下两个过程有关联(例如版本1中,必须先实现状态1,再状态2...)

3.要知道什么数据该封装,什么不该封装(例如例子中的currentIndex该封装,因为只有在内部实现时要用到它,而状态列表,元素,不该封装,因为与具体的过程实现没关系,而是与外部接口有关系)

4.可复用的过程可以抽象出来(例如例子中的按顺序执行几个行为)

5.与过程无关的数据可以抽象出来(例如例子中的三个状态,等待时间)

3.问题三:效率/性能问题:

版本1:两层循环

效率:两层循环,时间复杂度是O(n^2),效率很低

版本2:利用数组的排序方法sort,先排序,再遍历

效率:

排序时间复杂度n*log(n),遍历复杂度是O(n)

总的就是O(n*logn+n)

如果数组很大的话,效率高很多,比如n=10000

n^2=100000000,n*logn+n=50000

版本3:空间复杂度换时间复杂度

(大致思路就是将1和9中的1放在key上,另一个放在value上)

效率问题总结:

1.程序优化本质上是要用好的算法,要重视算法问题,尤其是在js不止被用在浏览器上时(例如用在服务端时,比如处理图片就要处理大量的像素点,所以算法很重要,可以在leetcode刷题,前端在程序员比鄙视链上,要正式这个问题,别把自己不当程序员)

2.其他优化要了解:http协议特点,资源请求特点,图片格式

4.总结:

1.好的代码职责要清晰,javscript不要用来操作样式

2.API要设计的合理:通用性,适度的抽象,可扩展性

3.用好的、合适的算法(前端程序员要把自己当程序员)

奇舞js笔记——第0课——如何写好原生js代码的更多相关文章

  1. html通过css,js实现div悬浮效果总汇,如原生JS实现滚动到一定位置实现div悬浮

    在我们的实际开发中,经常会遇到页面中需要悬浮效果,比如最早的客服联系,对联悬浮广告等,今天为大家介绍一些如何实现div悬浮的效果. 传统的fixed实现: 通过css中的属性position参数设为f ...

  2. Js笔记-第11课

    // 第11课         作用域精解     运行期上下文,当函数执行时,会创建一个成为执行期上下文的内部对象.一个执行期上下文定义了一个函数执行时的环境,函数每次执行时对应的执行期上下文都是独 ...

  3. Js笔记-第17课

    课 // 作业 //深度拷贝 var obj = { name:'rong', age:'25', card:['visa','alipay'], nam :['1','2','3','4','4'] ...

  4. vue.js笔记1.0

    事件: 事件冒泡行为: 1.@click="show($event)" show:function (ev) { ev.cancelBubble=true; } 2.@click. ...

  5. Pandas进阶笔记 (0)为什么写这个系列

    使用Pandas数年之久了,从最早的0.17版本开始接触Pandas,到现在0.25版本,踩过不少坑,面对各种稀奇古怪的bug抓耳挠腮.每每想要解决bug,或者想要实现一个特定的数据操作需求,首先想到 ...

  6. JavaScript学习笔记:你必须要懂的原生JS(二)

    11.如何正确地判断this?箭头函数的this是什么? this是 JavaScript 语言的一个关键字.它是函数运行时,在函数体内部自动生成的一个对象,只能在函数体内部使用. this的绑定规则 ...

  7. JavaScript学习笔记:你必须要懂的原生JS(一)

    1.原始类型有哪几种?null是对象吗?原始数据类型和复杂数据类型存储有什么区别? 原始类型有6种,分别是undefined,null,bool,string,number,symbol(ES6新增) ...

  8. JS面向对象方法(一): 使用原生JS 实现导航栏下多级分类弹出效果

    利用二级菜单的onmouseover/out事件 重新构建一级菜单 ".hover" 样式类 代码如下: CSS部分: 在原来的目标:hover样式中 增加 .hover状态 li ...

  9. HiShop2.x版本中的上传插件分析,得出所用的模板语言为Underscore.js 1.6.0且自己已修改

    效果: 上传组件非常的酷,但是分析其使用JS写法使用了模板语言的,代码如下: <script type="text/j-template" id="tpl_popb ...

随机推荐

  1. 第 7 章 MySQL 数据库锁定机制

      前言: 为了保证数据的一致完整性,任何一个数据库都存在锁定机制.锁定机制的优劣直接应想到一个数据库系统的并发处理能力和性能,所以锁定机制的实现也就成为了各种数据库的核心技术之一.本章将对 MySQ ...

  2. 点评阿里JAVA手册之编程规约(命名风格、常量定义、代码风格、控制语句、注释规约)

    下载原版阿里JAVA开发手册  [阿里巴巴Java开发手册v1.2.0] 本文主要是对照阿里开发手册,注释自己在工作中运用情况. 本文难度系数为一星(★) 码出高效.码出质量. 代码的字里行间流淌的是 ...

  3. Spring框架之IOC(控制反转)

    [TOC] 第一章Spring框架简介 IOC(控制反转)和AOP(面向方面编程)作为Spring框架的两个核心,很好地实现了解耦合.所以,简单来说,Spring是一个轻量级的控制反转(IoC)和面向 ...

  4. SQL数据库的多表查询

    多表查询分为 内.外连接 外连接分为左连接(left join 或left outer join).右连接(right join 或者 right outer join).和完整外部连接 (full ...

  5. 一键帮你复制多个文件到多个机器——PowerShell小脚本(内附PS远程执行命令问题解析)

    作为一个后台程序猿,经常需要把一堆程序集(DLL)或者应用程序(EXE)复制到多个服务器上,实现程序的代码逻辑更新,用以测试新的功能或改动逻辑.这里给大家介绍一个自己实现的PowerShell脚本,方 ...

  6. 各种Web漏洞测试平台

    Sqli Lab​支持报错注入.二次注入.盲注.Update注入.Insert注入.Http头部注入.二次注入练习等.支持GET和POST两种方式. https://github.com/Audi-1 ...

  7. Spring学习(14)--- 基于Java类的配置Bean 之 @ImportResource & @Value 注解

    学习如何使用@ImportResource 和 @Value 注解进行资源文件读取 例子: 先创建一个MyDriverManager类(模拟读取数据库配置信息) package com.beanann ...

  8. [0] TFS 分支/标签

    比较常见的版本控制分支策略有三种:不稳定主干策略.稳定主干策略.敏捷发布策略. 下面是对这几种策略的摘录: 不稳定主干策略 使用用主干作为新功能开发主线,分支用作发布. 被广泛的应用于开源项目. 比较 ...

  9. 在项目中利用TX Text Control进行WORD文档的编辑显示处理

    在很多文档管理的功能模块里面,我们往往需要对WORD稳定进行展示.编辑等处理,而如果使用微软word控件进行处理,需要安装WORD组件,而且接口使用也不见得简单易用,因此如果有第三方且不用安装Offi ...

  10. python list有关remove的问题

    在python 中进行一次简单的列表循环,当用到remove时出现了一个很有趣的现象, 代码如下: a=range(30) for i in a : if i%4!=0: a.remove(i) 这段 ...