### 变更历史 版本|变更内容|变更时间|变更人员 :-: | :-: | :-: | :-: v0.01|初稿|2019-06-17|wuxw ### 本页内容 主要讲述前段开发步骤。 ## 组件概念 vc组件框架是在WebService服务下的src\resources\components目录下html,js以及组件名+Component.java 文件组成的,主要是通过 自定义标签完成的, 指令原理为将HTML文件和js文件组合成一个文件 复制到 的位置,具体可以参考VueComponentElement.java类 系统在启动时,将src\resources\components目录下的HTML和js加载到内存中,可以查看VueComponentTemplate.java类,在解析 标签时根据name 查找对应的 html和js 将HTML和js 组合在一起,将替换为html和js组合的内容。 ## 流程页面 流程页面,如:地址https://demo.java110.com/flow/ownerFlow 中ownerFlow 就叫为一个流程页面,它存放在src\resources\view目录下 流程页面中包含,页面基本框架 菜单,头部导航栏,尾部版权栏等,中间为组件信息,公用js和css 引入。必须以Flow结尾,如demoFlow.html ## vue对象vc.component vc.component 其实就是一个vue对象,在页面加载最后去创建,页面组件中只存在一个vue对象,也就是多个组件公用一个vue对象,是用vc.extends()方法去继承 vue对象,extends参数介绍如下: ``` vc.extends({ propTypes: { }, data:{ }, watch:function(){ }, _initMethod:function(){ }, _initEvent:function(){ }, methods:{ } }); ``` ### propTypes节点 组件参数,一般情况下这个节点可以不用写,只有 引入组件时,需要传参时,才会用到。 ### data节点 data节点就是vue的data节点用作数据绑定,data下的最好是一个对象,对象名取名为当前组件名+info组成,对象下再去写需要绑定的字段信息,这样做的目的是为 多个组件之间取相同的字段名称 导致影响显示效果。 ### watch节点 watch节点为 vue的watch节点 ### _initMethod节点 组件在加载时执行的代码可以放到这里,访问data下变量或method下的方法时必须 加入前缀 vc.component. 例如访问loadData方法时,vc.component.loadData()。 ### _initEvent 节点 组件在加载时 做事件监听用,访问data下变量或method下的方法时必须 加入前缀 vc.component. 。 ### methods 节点 等同于 vue 的method,各个组件的方法名建议不要一直,防止冲突,访问data下变量或method下的方法时必须 加入前缀 vc.component. 。 ## 组件之间通信 组件通信主要用 监听方法 vc.on(componentName,businessAction,function(_param){}); 和 触发方法vc.emit(componentName,businessAction,_param); ### vc.on 方法 componentName 当前组件名 如listDemo businessAction 业务动作 loadData, function(_param){} 再监听到事件后触发函数 ### vc.emit方法 componentName 要触发的方法的组件名,要出发businessAction 业务动作,_param 传递参数,以对象的方式传递 ## 组件传参 当一个组件被多个页面引用时,当组件处理完业务时,将结果传递给父组件,这样就引入一次组件就得在触发的地方多加一个触发情况,比较麻烦,测试我们引入组件参数 ``` propTypes: { emitChooseOwner:vc.propTypes.string }, ``` 将触发的父组件名称通过参数 emitChooseOwner 传入进来,如 ``` ``` 在组件中使用时,用$props.emitChooseOwner 方式使用,也就是在变量之前加入 $props. 如: ``` vc.emit($props.emitChooseOwner,'chooseOwner',_owner); ``` ## vc 组件提供函数 ### vc.http.post方法 vc.http.post(componentCode,componentMethod,param,options,successCallback,errorCallback); http post 异步请求方法 componentCode 一般为当前组件名 是java组件的beanId componentMethod 为组件中方法名 param 为post的参数 options 为 默认传 { emulateJSON:true } 对象 successCallback 成功时的回调函数 errorCallback 失败时的回调函数 ### vc.http.get方法 vc.http.get(componentCode,componentMethod,param,successCallback,errorCallback); http get 异步请求方法 componentCode 一般为当前组件名 是java组件的beanId componentMethod 为组件中方法名 param 为get的参数 successCallback 成功时的回调函数 errorCallback 失败时的回调函数 ### vc.jumpToPage方法 vc.jumpToPage(url) 为页面跳转方法 url为跳转页面的地址 如跳转到业主页面则 写 /flow/ownerFlow ### vc.getCurrentCommunity 方法 vc.getCurrentCommunity(); 获取当前菜单方法,返回值为如 {"communityId":"123213","name":"测试小区"} ### vc.copyObject方法 vc.copyObject(org,dst);将org 对象中属性拷贝到 dst对象中属性相同的属性值 ### vc.getParam 方法 vc.getParam(_key); 获取当前地址栏上的参数值 ### vc.objToGetParam 方法 vc.objToGetParam(obj); 对象转为get参数方法,不包含?号