您现在的位置:新闻首页>综合 > vue和微信小程序的区别是什么
vue和微信小程序的区别是什么
区别:1、 vue的钩子函数在跳转新页面时,钩子函数都会触发;但小程序的钩子函数,页面不同的跳转方式,触发的钩子并不一样。2、vue中使用v-if和v-show控制元素的显示和隐藏;小程序中使用wx-if和hidden控制元素的显示和隐藏。
相关:《vue.js教程》、《微信小程序教程》
vue和微信小程序的区别
一、生命周期
先贴两张图: vue生命周期
小程序生命周期
相比之下,小程序的钩子函数要简单得多。 vue的钩子函数在跳转新页面时,钩子函数都会触发,但是小程序的钩子函数,页面不同的跳转方式,触发的钩子并不一样。onLoad:页面加载一个页面只会调用一次,可以在 onLoad 中获取打开当前页面所调用的 query 参数。onShow:页面显示每次打开页面都会调用一次。onReady:页面初次渲染完成一个页面只会调用一次,代表页面已经准备妥当,可以和视图层进行交互。 对界面的设置如 wx.setNavigationBarTitle请在 onReady之后设置。详见生命周期。onHide:页面隐藏当 navigateTo或底部tab切换时调用。onUnload:页面卸载当 redirectTo或 navigateBack的时候调用。数据请求在页面加载请求数据时,两者钩子的使用有些类似,vue一般会在 created或者 mounted中请求数据,而在小程序,会在 onLoad或者 onShow中请求数据。
二、数据绑定
vue:vue动态绑定一个变量的值为元素的某个属性的时候,会在变量前面加上冒号:,例:
<img :src="imgSrc"/>
小程序:绑定某个变量的值为元素属性时,会用两个大括号括起来,如果不加括号,为被认为是字符串。例:
<image src="{{imgSrc}}"></image>
三、列表渲染
直接贴代码,两者还是有些相似: vue:
小程序:
Page({ data: { items: [ { message: 'Foo' }, { message: 'Bar' } ] } }) <text wx:for="{{items}}">{{item}}</text>
四、显示与隐藏元素
vue中,使用 v-if 和 v-show控制元素的显示和隐藏。 小程序中,使用 wx-if和 hidden控制元素的显示和隐藏。
五、事件处理
vue:使用 v-on:event绑定事件,或者使用 @event绑定事件,例如:
<button v-on:click="counter += 1">Add 1</button> <button v-on:click.stop="counter+=1">Add1</button> //阻止事件冒泡
小程序中,全用 bindtap(bind+event),或者 catchtap(catch+event)绑定事件,例如:
<button bindtap="noWork">明天不上班</button> <button catchtap="noWork">明天不上班</button> //阻止事件冒泡
六、数据双向绑定
1、设置值
在vue中,只需要再表单元素上加上 v-model,然后再绑定 data中对应的一个值,当表单元素内容发生变化时, data中对应的值也会相应改变,这是vue非常nice的一点。
<p id="app"> <input v-model="reason" placeholder="填写理由" class='reason'/> </p> new Vue({ el: '#app', data: { reason:'' } })
但是在小程序中,却没有这个功能。那怎么办呢? 当表单内容发生变化时,会触发表单元素上绑定的方法,然后在该方法中,通过 this.setData({key:value})来将表单上的值赋值给 data中的对应值。 下面是代码,可以感受一下:
<input bindinput="bindReason" placeholder="填写理由" class='reason' value='{{reason}}' name="reason" /> Page({ data:{ reason:'' }, bindReason(e) { this.setData({ reason: e.detail.value }) } })
当页面表单元素很多的时候,更改值就是一件体力活了。和小程序一比较,vue的 v-model简直爽的不要不要的。
2、取值
vue中,通过 this.reason取值。 小程序中,通过 this.data.reason取值。
七、绑定事件传参
在vue中,绑定事件传参挺简单,只需要在触发事件的方法中,把需要传递的数据作为形参传入就可以了,例如:
<button @click="say('明天不上班')"></button> new Vue({ el: '#app', methods:{ say(arg){ consloe.log(arg) } } })
在 小程序中,不能直接在绑定事件的方法中传入参数,需要将参数作为属性值,绑定到元素上的 data-属性上,然后在方法中,通过 e.currentTarget.dataset.*的方式获取,从而完成参数的传递,很麻烦有没有...
<view class='tr' bindtap='toApprove' data-id="{{item.id}}"></view> Page({//在此我向大家一个前端全栈开发交流圈:619586920 突破技术瓶颈,提升思维能力 data:{ reason:'' }, toApprove(e) { let id = e.currentTarget.dataset.id; } })
八、父子组件通信
1、子组件的使用 在vue中,需要: 1、编写子组件 2、在需要使用的父组件中通过 import引入 3、在 vue的 components中注册 4、在模板中使用
//子组件 bar.vue <template> <p class="search-box"> <p @click="say" :title="title" class="icon-dismiss"></p> </p> </template> <script> export default{ props:{ title:{ type:String, default:'' } } }, methods:{ say(){ console.log('明天不上班'); this.$emit('helloWorld') } } </script> // 父组件 foo.vue <template> <p class="container"> <bar :title="title" @helloWorld="helloWorld"></bar> </p> </template> <script> import Bar from './bar.vue' export default{ data:{ title:"我是标题" }, methods:{ helloWorld(){ console.log('我接收到子组件传递的事件了') } }, components:{ Bar } </script>\
在小程序中,需要: 1、编写子组件 2、在子组件的 json文件中,将该文件声明为组件
{ "component": true }
3、在需要引入的父组件的 json文件中,在 usingComponents填写引入组件的组件名以及路径
"usingComponents": { "tab-bar": "../../components/tabBar/tabBar" }
4、在父组件中,直接引入即可
<tab-bar currentpage="index"></tab-bar>
具体代码:
// 子组件 <!--components/tabBar/tabBar.wxml--> <view class='tabbar-wrapper'> <view class='left-bar {{currentpage==="index"?"active":""}}' bindtap='jumpToIndex'> <text class='iconfont icon-shouye'></text> <view>首页</view> </view>//在此我向大家一个前端全栈开发交流圈:619586920 突破技术瓶颈,提升思维能力 <view class='right-bar {{currentpage==="setting"?"active":""}}' bindtap='jumpToSetting'> <text class='iconfont icon-shezhi'></text> <view>设置</view> </view> </view>
2、父子组件间通信
在vue中
父组件向子组件传递数据,只需要在子组件通过 v-bind传入一个值,在子组件中,通过 props接收,即可完成数据的传递,示例:
// 父组件 foo.vue <template> <p class="container"> <bar :title="title"></bar> </p> </template> <script> import Bar from './bar.vue' export default{ data:{ title:"我是标题" }, components:{ Bar } </script> //在此我向大家一个前端全栈开发交流圈:619586920 突破技术瓶颈,提升思维能力 // 子组件bar.vue <template> <p class="search-box"> <p :title="title" ></p> </p> </template> <script> export default{ props:{ title:{ type:String, default:'' } } } </script>
子组件和父组件通信可以通过 this.$emit将方法和数据传递给父组件。
在小程序中
父组件向子组件通信和vue类似,但是小程序没有通过 v-bind,而是直接将值赋值给一个变量,如下:
<tab-bar currentpage="index"></tab-bar>
此处, “index”就是要向子组件传递的值 在子组件 properties中,接收传递的值
properties: { // 弹窗标题 currentpage: { // 属性名 type: String, // 类型(必填),目前接受的类型包括:String, Number, Boolean, Object, Array, null(表示任意类型) value: 'index' // 属性初始值(可选),如果未指定则会根据类型选择一个 } }
子组件向父组件通信和 vue也很类似,代码如下:
//子组件中 methods: { // 传递给父组件 cancelBut: function (e) { var that = this; var myEventDetail = { pickerShow: false, type: 'cancel' } // detail对象,提供给事件监听函数 this.triggerEvent('myevent', myEventDetail) //myevent自定义名称事件,父组件中使用 }, } //父组件中 <bar bind:myevent="toggleToast"></bar> // 获取子组件信息 toggleToast(e){ console.log(e.detail) }
如果父组件想要调用子组件的方法 vue会给子组件添加一个 ref属性,通过 this.$refs.ref的值便可以获取到该子组件,然后便可以调用子组件中的任意方法,例如:
//子组件 <bar ref="bar"></bar> //在此我向大家一个前端全栈开发交流圈:619586920 突破技术瓶颈,提升思维能力 //父组件 this.$ref.bar.子组件的方法
小程序是给子组件添加 id或者 class,然后通过 this.selectComponent找到子组件,然后再调用子组件的方法,示例:
//子组件 <bar id="bar"></bar> // 父组件 this.selectComponent('#id').syaHello()
小程序和vue在这点上很相似
编程学习!!
-
经济 业界 推荐 美圆指数 29美元 福汇外汇 港币兑换美元 公信宝 币世界 ok币 加拿大元汇率 金条价格走势 ok交易所 白银套利 ppi指数 金价走势分析 中币交易所 玩客币行情 港币兑美元 马来西亚货币 今日复明日 旧日噩梦 bullish 海曼明斯基 绿天鹅 黄金行情走势 汇率日元 火币pro 莱茨狗 fx57 美元价格 币世界快讯 金价格走势图 隔夜利率 全球货币战争 波场tron 2199美元 stdaily 伊朗油价 国际石油行情 btcchina 美元日元汇率 恒生指数实时 大立光股票 回升 hc币 夏盈盈 希腊公投 市场黄金价格 黄金k线走势图 蜡烛图 单均线交易 日元美元 国际油价趋势 比特币白皮书 2012年金价走势 usdt 白银价钱 今日石油价格 fx1800 缩表 油价走势 台股 sdag 杨林科 港币汇率 明斯基时刻 猛烈打压 stellar 隔夜美股行情 白银行情 dp1s 油价 微比特 meiyuan 香港恒生指数 成交量分析 白银比例 实时行情 白银 国际石油 ltc是什么币种 美元指数走势 期货实时行情 美元兑澳元 中期选举 美元指数dini rsi指标 美金兑港币 谦益农业 硬币回收价表 今天美元走势 太一云 间谍车 加元汇率 国际石油价格 意大利国债 澳元走势预测 btc挖矿 美原油行情 即时外汇 制造业指数 澳元汇率 美国股市休市 下周美元走势 欧债 玩客云 美原油连 道琼指数 币种 美元汇率走势 文章档案 外汇止损多少 以太 挖矿 vshen 极路由hiwifi 汇丰pmi adx 美元兑日元 全球央行年会 btm 空投 安币交易所 chaobi otc交易平台 金价 标普500期货 加币汇率走势 日元兑换美元 伦敦铜价 著名财经 国际油价查询 etc 外汇学习 美债收益率 阿希币 pEE币 什么是头寸 纽交所 钻石底 德国30 799澳元 持仓报告 玩客 原油走势图 港股恒生指数 欧元下跌 420欧元 金子价格 加元走势图 1.11111E+11 xrp 美元指数k线图 金价走势预测 最新黄金价格 铜价格走势图 黄金降价 汇率欧元 金针探底 原油成本 美元 strllar 泰奇猫 圈牌 金价走势 以太币 lme铜实时行情 eos价格走势 欧元兑美金 外汇基本知识 联邦基金利率 伦敦银走势图 基本面分析 空头回补 云鱼 py6是什么货币 rsi指标详解 265万澳元 国际油价格 gateio wti原油走势图 门罗币 白银价格走势 欧盟财长会议 外汇咨询 交叉盘 外汇初学 房价指数 cbt 比特股 ltc 隐私政策 石油危机 日圆汇率 英国股市指数 原油最新价格 行情报价 自动减支 黄金市场价 全球指数 imtoken 币投资 10美金 eos币价格 相对强弱指标 黄金年走势图 美原油 加元美元 虚拟币 值多少钱 国际油价 外汇哈里森 外汇交易分析 白银价格分析 日bi btcc 标准普尔500 wti原油价格 zbcom 和币 度宇宙 技术指标分析 全球股市指数 币久 白银价格趋势 克龙 银行回收硬币 hiwifi 贝尔链 美元兑换欧元 后座议员 黄金市场行情 德拉基讲话 UES 道琼斯k线图 美元对日元 k线图分析 恒生指数 英国脱欧时间 港股指数 比特币之父 bin 今日原油 jinjia 日经225指数 比特币价格 英镑汇率 742 大立光 外汇走势 上吊线 趣步APP被调查 肖野 理财三 铜走势图 艾达 吞阳 coinex 欧元美金 赵长鹏 法郎汇率 9g游戏 英国脱欧结果 硅谷bbs 俄罗斯火星人 铜价 什么叫头寸
-
欢迎 什么是头寸 今天美元走势 日经225指数 营业 协议 优缺点 关爱 ppi指数 金价格走势图 联邦基金利率 德拉基讲话 ok币 强征 沙特 受伤 就应 人心 上下其手 妻子 砸伤 82岁 小伙 大学生 结果 罚单 中学 买的 开锣 主题 外卖 入网 Xperia 秀翻 上海 空砍 盛典 调查 客户端 财经新闻 DCR 今天国际油价 央行喊话空头 灰犀牛事件 墨西哥比索 黄金市场价格 k线图技术分析 GFK 钯金价格走势 美国纳斯达克 外汇分析 安币 gct是什么 避险货币 外汇超短线 通缩和通胀 k线图分析 ltc 美圆指数 360币 多国 警员 科技 3号 阴阳合同 有限公司 下水 不会 亚洲 防空导弹 沦丧 42条 手机 闪婚 前夫 枪杀 身 两男 滴滴 烘焙 新派 也可以 用了 市场 这场 之处 提高 索尼 限制 三星 升级 地方 越来越 公益 孩子 光明 发言人 招生 有利于 人才培养 根据 扶贫 在京 游戏 依法 攻略 东鹏 家装 主材 辅材 100平米 地板 新人 剑道 三角 总决赛 国际 中智 健康 开业 加深 双方 天一 无脑 气疯 罗心痛 他见 张继 科遭 成为 表率 罗马 舍得 亮相 数字 群星 衣品 她们 春夏 来源 献给 已成 你我 倾覆 柏林 制服 伤者 至少 政治 决定 六国 加征 少女 甜美 欧盟 正式 森友学园 文件 摇号门 开发商 邱小平 又讲 督办 27起 明确 遂溪 当前 着力点 有关 合同 扑灭 侦察 南海 参加 只是 摧岛 想干 刘诗 马思 一体 8寸 宣布 冰点 成香 入股 5月 系列 到了 华为 屏幕 静电 导致 刘强 东晒 七彩虹 显卡 去年 谷歌 只要 排行 进入 斩获 地震 使用 非官方 她去 神器 实为 可查 失误 户型 五孔 多少 回升 克龙空间 明斯基时刻 欧盟财长会议 三弓强弩 第六计 fx外汇 法国cac 10美元 黄金行情分析 净多头头寸 小牛链 熊路 最近黄金走势 白银价格 白银套利交易 茶党 失业率 200瑞士法郎 金克拉泽 港币兑换美元 比特币矿机 净头寸 提高债务上限 白银交易 外汇趋势分析 俄罗斯物价 特朗普讲话 币易 外汇新闻 外汇趋势 非农 环亚外汇 美金兑换港币 德斯特尼 满楼水平 k线图解读 库尔德公投 印度通货膨胀 打压市场 七国集团 招财币 引而不发 黄金实时 黄金交易 今天原油行情 纽币汇率 轧空 蒙币 比特币交易 亚洲股市 pee 比特币行情 今日油价走势 黄金美元
-
国际石油行情 强征 ppi指数 ok币 美原油行情 当天 美国 中国 人心 驱逐舰 日经225指数 ok交易所 rsi指标 什么是头寸 罪证 金价格走势图 外汇止损多少 极路由hiwifi 回升 usdt 美圆指数 新时代 欧盟财长会议 马来西亚货币 海曼明斯基 wti原油走势图 k线图分析 德拉基讲话 协议 关爱 放学 蜡烛图 币世界 推荐 有限公司 经济 港币兑换美元 外汇交易分析 3号 全面 营业 欢迎 沦丧 国防部 欧洲 房价指数 黄金行情走势 fx57 otc交易平台 美元日元汇率 波场tron 太一云 多国 沙特 用人 513部队 心痛 今天美元走势 港币兑美元 金条价格走势 gwallet 伦敦银走势图 道琼指数 玩客币行情 恒生指数实时 dp1s 今日复明日 莱茨狗 公信宝 jinjia 受伤 税延型 回归 朋友 业界 猛烈打压 2199美元 市场黄金价格 汇率日元 白银价钱 福汇外汇 美元指数k线图 10美金 美元价格 美元兑澳元 hc币 军事 警员 就应 彻底 总理 2018 Marc 贵的 fx1800 白银套利 加拿大元汇率 锁仓 hiex 联邦基金利率 ltc gateio 中币交易所 火币pro 中国佬汉堡 中青 巴拿马 防空导弹 法院 靓号 女子 对方 上门 一开 明斯基时刻 美金兑港币 港币汇率 隔夜利率 隔夜美股行情 技术指标分析 文章档案 美元兑日元 29美元 国际石油价格 澳元走势预测 世界杯 多好 安缇 蝎子 张勇 大展 什么 过人 一条 网售 辅料 大立光股票 黄金k线走势图 金价走势分析 实时行情 希腊公投 外汇走势 比特币白皮书 币世界快讯 云鱼 夏盈盈 日元兑换美元 加币汇率走势 旧日噩梦 日元美元 空投 谦益农业 印度 校外 窗口 手术室 31.7万 上当 校园 鲜 fashion 27日 这场 美元 第三代 功能 Beta 三星 三角 锐龙 3000 内部资料 Comic 绿天鹅 纽交所 bullish ethos 天然气分析 币投资 后座议员 圈牌 hiwifi 吞阳 台股 2012年金价走势 间谍车 微比特 耳机 3万 看看 真 扔书 民警 wifi 不能 衣服 快步 东来 号的 主动 vivo 11.4.1 解 3个 首轮 清凉 美国总统 核实 7500元 Mate 一笔 一米 冰雪 stdaily 单均线交易 今日石油价格 r币 深谙此道 脱欧b计划 usdcnh dailyfx FTSE bitcoin nexus10 肖野 eos币价格 金价走势预测 缩表 monaco 美元指数dini 币种 全球货币战争 钻石底 海军 两艘 一个 警方 10分钟 欧冠 后边 开出 人说 太太 gaga 毛利 如飞 变老 刷屏 优缺点 企业 上手 数据 专业 比 东部 信 广东 40个 来了 天选之子 风口 汇丰pmi adx 加元美元 白银 白银价格趋势 sosobtc ifo