您现在的位置:新闻首页>综合 > 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 俄罗斯火星人 铜价 什么叫头寸
-
开启 民警 沟通 气炸 怎样 18岁 货币是商品吗 比特币挖矿机 澳元汇率走势 ltc是什么币种 猫日 张本 横扫 miota 什么是macd 小米1s评测 钱却 黏性 烧钱 避免 依法 瓷砖 BOTN2018 印度通货膨胀 台湾股票行情 加剧 反对 即将 优缺点 什么 铺装 躁动 6.1级 12时 唐讯 全球股票指数 油价走势图 体验 和平列车 专家 劝其 不顾 受困 这些 带来 畅玩 西北 足球大师2018 金价走势分析 最新石油价格 币安 英国公投脱欧 外汇交易入门 澳元走势分析 白银最新价格 聚币 美元兑 比特币行情 18美元 2020年后的金价 银价走势图 美元兑港币 太极链 加州 技术活 不会 抢救 惨遭 永久 闪婚 扔书 选科分 助力 离队 牛仔 是个 不断 国企 两车 贼喊捉贼 OPPO 预约 搜索 战火 贵州 黄金行情走势 小蚁股 美国道指 FOMO 财经日历 渡边太太 外汇掉期 黄金咨询 追踪止损 文章档案 民众 选人 热烈 说上 穹顶 尹卓 维持 对话 英法 不醒 他人 各不相同 捕鱼 新派 茶饮 vivo 苹果 系统 索尼 Note9 考场 马可波罗 哪个 质量 你我 走心 法官 长相 iPhone 去年 19日 联赛 足梦 吉祥物 2199美元 ppi指数 英镑美元汇率 eth 纽交所 亚马逊财报 英镑 今天国际油价 俄罗斯物价 黄金最高价格 深圳财经 白银新闻 fx回归 美元跌下神坛 铜期货 bitebi 外汇分析 daily怎么读 日经指数225 k线图分析 油价走势 韩民众 联合国 特朗 泄露 封信 人民日报 培训 片酬 音乐 当天 集团 签署 演讲 挑战 道德 拍卖 凌晨 七级 熬夜 枪杀 热情 中学 就是 卡拉 补贴 选址 盘点 未来 新手机 办学 写入 选材 选购 装修材料 房屋 区别 地面 男篮 年近 中国队 让人 克林顿 发表声明 精通 龃龉 环境 达标 战机 军报 阅兵 发 一天 后视镜 学院 新思想 一平 引领 幼儿 Comic 白银走势分析 闪电封锁 外汇初学 btc fx1800 独股一箭 白银报价 澳元走势 意大利脱欧 澳币 港元美元 黄金持仓量 explore2fs 比特 k线图技术分析 澳元兑美元 澳币汇率 e0s币最新价格 新加坡元汇率 ance 白银分析 80欧元 金价走势图 脱欧公投 加元汇率走势 台湾股市 sunkcost 通胀预期 比特比 吞噬太阳国语 加元走势分析 欧元换美元 黄金实时行情 外汇超短线 英国汇率 黄金实时报价 eos价格走势 虚拟货币开发 gotowebinar 台股 sdag fx57 btcchina 间谍车 ok交易所 许子敬 足球 美日 失望 反响 适合 阴阳合同 就应 将被 上班 长江口 巴拿马 攻击 弃核
-
印度卢比 你吗 关于黄金交易 2300X 目的 eunice 美圆 国际原油k线图 创造 外汇 韩币汇率 bitun 攻击 发表声明 财务省 美缝剂 欧元美元 FOMO 意大利股市 ltc是什么币种 庄家杜均 银价走势 火锅 怎样 张本 已致 站在 金价走势分析 掉期交易 8l9970 q币交易平台 美元指数k线图 旧日噩梦 揭幕战 获赔 搭载 这条 头肩 459美元 台湾股票行情 夏盈盈 茶饮 超模 酷云 csmoney 纽币 里拉汇率 btctrade 中国 完全 依法 鏖战 实时行情 塞浦路斯危机 瑞士货币 外汇趋势分析 废金 外汇止损多少 gateio 强国 用户 处去 12nm 行业 状元 日经 澳元走势分析 国际黄金走势 dragon 12334 即时外汇牌价 社评 特色 主材 铺装 地板 总决赛 他来 晚年 因卡 大火 小时 1199元 第五名 道指走势 xunleiyun 灰犀牛事件 唐讯 印度通货膨胀 2020年金价预测 特别提款权 bitebi 加币 小米1s评测 火币比特币 银价走势图 lme铜实时行情 加元走势图 国际油价趋势 亲亲 提高 系统 获利 科学 有利于 齐聚 余人 东晒 定向 五孔 多少 全新 空头头寸 bullish 外汇知识入门 今日日历 狗币 墨西哥比索 yingbang 比特币现金 黄煜坤 令吉 日经225指数 英国新闻 rbcc 现在金子行情 chaobi 为国 拍卖 钱却 左眼 身陷 一下 顾客 容易 供应商 发言人 兴趣 双一 选材 哪个 质量 能量 改判 举办 方领 群星 青年 至少 甜美 欧盟 文件 时限 商贸城 南海 闪充 材料 开关 战火 新版本 什么是比特币 第六计 港股实时行情 比特币工厂 原油最新消息 英国公投脱欧 瑞典货币 学习外汇 ico币 云币 汇率实时走势 币圈 btc挖矿 地球 副市长 音乐 协议 惨遭 澳媒 老赖 侧脸 球迷 2018 持续 品类 欧洲 Note9 高校 招生计划 秀翻 满满的 牛仔 骗子 不断 触动 两车 好酒 阅兵 地震 Ryzen 失误 聚苯乙烯 隔夜美股行情 fomc 澳币汇率 比特币白皮书 中币交易所 币久 莱茨狗 行情分析 体验 法国 泄露 总书记 动员令 微博 日军 对话 肢解 大爷 闪婚 传销 热情 fashion 品牌 什么 化工 专业 灵魂 游戏 齐祖 裙摆 闪耀 海域 抗诉 决定 遭遇 开启 刘强 1080Ti 登陆 骑勇 小蚁股 欧元 白银套利交易 早晨之星 澳币 白银最新价格 qe4 聚币 okex fx 原油价格 外汇掉期 fx回归 极路由1s 美国国债利率 马来西亚币 欧洲央行会议 美元兑港币 追踪止损 太极链 石油危机 成交量分析 ism制造业指数 韩民众 宇航员 加州







