如何实现前端模块化开发

如何实现前端模块化开发,第1张

前端如果想做模块化开发,首先需要针对每一种资源(

JavaScript

CSS

、模板等)寻找

一种模块与集成方案,然后需要根据情况的不同选用不同的工具框架拼凑出来。

SeaJS

是一个适用于

Web

浏览器端的模块加载器。使用

SeaJS

,可以更好地组织

JavaScript

代码。

不知道别人怎么做的,我自己现在的做法是,基本通用的功能做成一个

js

文件

js

html

标签和

style

样式,只需要一个

div

带上

id

调用一下就

ok

了,比如图片上传。而一

些常用但不通用的功能做成一组文件,包括

js

和一定的

html

结构还有一个

css

文件,也可

能还有图片什么的,有时候甚至做成不用调用,直接加载就能用。

至于具体的调用方法,

大概就是

window

定义一个变量,

放入调用的这个功能的

function

初始化一个模块,

并返回这个模块闭包中的一些方法用来 *** 作或者获取和设置一些模块闭包

内的变量。

JavaScript

目前比较拿的出手的,也就是

JavaScript

的模块化,比如

AMD

或者

CMD

等等,分别可以使

RequireJS

SeaJS

去年在研究基于

Backbone

的框架

Marionette

时,想与

Sea.js

结合使用。现在来看这种组合

是完全没有必要的。

Marionette

提供了模块化的组织方案,反而生拉硬扯在一起,冲突得很

难受。其实把

JavaScript

文件一列放在

HTML

中也没什么问题。

究竟使用什么来实现

JavaScript

往往与选择的

JavaScript

框架有关,

Backbone

可以

AMD

也可以

CMD

。选

AngularJS

直接引用就行。

CSS

CSS

模块化应该是两方面的问题——

一是模块必须有一套基础样式。与

JavaScript

相比,

CSS

冲突简直是家常便饭,

Shadow DOM

还没成熟,

原生的

CSS

样式隔离还在路上。

所以必须有一套基础样式来规定这一套模块化组

件的样式。我们可以选

Bootstrap

,如果闲它太重,也可以自己写。

其次,每个组件必须有命名空间,避免组件间样式冲突。如果选择使用

LESS

SASS

等,那

就比较好办,它们的缩进语法避免写很多重复的

CSS

代码。

HTML

模板

如果使用

AngularJS

AngularJS

已经帮您解决了模板模块化的问题,

AngularJS

可以根据模

块代码中的引用加载对应的

HTML

。如果使用

Backbone

,可以选择各种各样的模板引擎,

Mustache

?不过比起

AngularJS

就低端些,我们必须自己处理模板文件,要么通过模块加载

器通过

XHR

请求,然后动态编译;或者将

Mustache

编译成

JS

,在当做模块加载。

图片、字体?

放在使用他们的模块中,该怎么引用就怎么引用。

国际化文件?这些就不多说了,总之,每种文件需要选定一种开发的组织方式。

模块分发

模块采用统一的模式来开发之后,只需选定一种包的分发方式就行了——

Bower

npm

不适

合这样的场景,

npm

的版本管理太过细致了。如果同一个项目中允许出现同一模块的不同

版本,事情就做的太过复杂了。

发布上线

发布上线必须一个以终为始的过程。

如果你不追求网站或者应用的速度,

那就把那些开发文

件直接丢到生产服务器上去吧。别说,我还真见过这样的商用的网站。

如果讲究一些方案,

资源合并成数个文件,

代码线上组合和运行方式完全可以与本地开发不

一样。只需要功能在就行。

JavaScript

代码打成一个文件,或者两个?都行。如果使用

RequireJS

,那

RequireJS

提供了打

包的工具,打包成几个文件,什么粒度,都行。如果是

Sea.js

也有对应的工具。就算文件都

是一个一个列出来,我们也总是可以打出来你想要的文件。

CSS

等等其他资源都是如此,就算开发时各自不同的结构模式,打包时都是可以打的。

至于上线

CDN

,版本号缓存什么的并不在本文的讨论范围之内。

总结

前端模块没有什么特效药。唯一要遵守的原则就是,

比起

Node.js

来讲,每种资源必须要

有一种自己的开发和上线组织方式

Node.js

开发和上线都是一致的)

,开发和上线完全可

以是两种方式,

大可不必人云亦云,

只要适合可以随意组合;

CSS

CSS Scoped Style

正式使

用之前,应该有一套基础样式和沙盒(模块样式命名空间)

每个模块中的

HTML

怎么办,

如果我们使用的框架是

Backbone

注定我们要将

HTML

模板转

换成

JavaScript

模块,或者使用模块加载器的插件来实现。如果我们使用

AngularJS

,那倒是

可以交由

AngularJS

。发布时

Backbone

中的模块使用

AMD

打包,

AngularJS

可以使用

Grunt

内联到页面中。

HTML

模块也没有固定的模式,没有固定的

SDK

来解脱我们。我们只能组合现有的工具!

CSS

就更不用说了,分开写,使用

LESS

SASS

来组织?再一次没有固定的模式没有

SDK

动态加载模块用的模块importlib 里面的import_module(“字符串模块路径”, 相对路径包名)

2.getattr(对象,“字符串属性”,默认值)

补充

任意创建一个文件夹,在里面同级创建f1-f4.py的四个文件。

内容如下:

f1.py

f2.py

f3.py

f4.py

f5.py

f4.py:通过动态导入模块,动态添加属性 删除。可以解决接口自动化中的动态传参

F5.py: 通过传参的方式,去获取类的实例方法,可以做到不知道需要哪个方法的时候,用字符串的方法去调用需要的方法。接口自动化中参数化的时候可以用到。

反射机制,当通过类名去反射得到的实例方法,需要传类名进去。通过self或者对象得到的实例方法,不需要传self或者类名。如果是实例对象或者类 去调用静态方法, 都不用给函数传self cls

1

<input type="text" autocomplete="on">

input 的autocomplete属性默认是on,但某些浏览器还是需要你手动写上默认值才有效,其含义代表是否让浏览器自动记录之前输入的值,off:则关闭记录。该功能十分垃圾,交互让人诟病不已,每次必须提交刷新后才能记住存入历史,不推荐,垃圾。

原生基础上增强交互

我并不是说去改变autocomplete="on"的原生功能,而是通过另一种方式实现我们想要的效果,首先我们要准备一个输入时候出现下面那个下拉框可选性,那么这个东西其实原生是有的,并不需要我们去自己写,如下:

1

2

3

4

5

<input type="text" class="form-control" id="phone_number" value="1876487748" placeholder="请输入手机号码/imei/accid" list="cars">

<datalist id="cars">

<option value="17314459887"></option>

<option value="1876487748"></option>

</datalist>

动态缓存

上面已经做好了模型,但并不能实现动态记忆,而是写死的两个,很显然,我们需要用到本地缓存,将我们每次提交查询的值push到当前datalist的数据中去

1

2

3

4

5

6

7

8

9

10

11

// 提交之前先判断需不需要存储,如果当前数据中已经存在的,那么不去重复添加

var dataInput = $('#phone_number').val()

var locData = JSON.parse(localStorage.getItem('dataList'))

if (!locData || !locData.includes(dataInput)) {

if (!locData) {

localStorage.setItem('dataList', JSON.stringify([dataInput]))

} else {

localStorage.setItem('dataList', JSON.stringify(locData.concat([dataInput])))

}

}

scope.addDataList()

1

2

3

4

5

6

7

8

9

10

11

12

13

// 通过jq将数据插入到datalist中

addDataList: function() {

var opt = ''

var locData = JSON.parse(localStorage.getItem('dataList'))

if (locData.length >15) {

locData = locData.slice(locData.length - 15, locData.length)

}

console.log('locData', locData)

for (var i = 0, len = locData.lengthi <leni++) {

opt += '<option value="' + locData[i] + '">'

}

$('#cars').html(opt)

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11801929.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存