经常有些组件功能比较复杂(js比较多),但是他的ui比较简单(html,css少)。这时候组件代码是比较臃肿庞大的,比较难维护,定位一个函数可能都得找一会。但是又不好继续拆分成子组件了,因为ui不好再拆分了。这时候怎么去拆分,让这些js模块化一些?
现在想到的是用mixin,有其他更方案吗?
经常有些组件功能比较复杂(js比较多),但是他的ui比较简单(html,css少)。这时候组件代码是比较臃肿庞大的,比较难维护,定位一个函数可能都得找一会。但是又不好继续拆分成子组件了,因为ui不好再拆分了。这时候怎么去拆分,让这些js模块化一些?
现在想到的是用mixin,有其他更方案吗?
通用方法写成组件,然后各种import,require 引入减少重复劳动。
比如统一处理请求。
webService.js
比如自定义的处理字符串的方法
string.js
用于表单校验的方法集合
validate.js
27 回答13.1k 阅读
6 回答2.3k 阅读✓ 已解决
8 回答3.5k 阅读✓ 已解决
6 回答1.3k 阅读✓ 已解决
5 回答5.3k 阅读✓ 已解决
4 回答1.6k 阅读✓ 已解决
6 回答1.1k 阅读
那我来说说我在开发中通常的做法,就拿一个登录的场景来说吧。
首先我会创建一个api文件夹,用来管理所有的请求接口。比如登录的接口是http://xxx.xxx.com/api/login,需要传递用户名(手机号)、密码。
我会在api下面新建一个login.js(这个文件负责处理登录的逻辑)
然后在login.vue组件里面导入
import {login} from "../api/login";
然后在点击登录按钮的事件中:
这样一样,就将所有的逻辑交给对应的js文件去处理,vue组件只负责调用这样的模块。