本文介绍了如何使用webpack在vue项目中写jsx语法,分享给大家,具体如下:
我们知道Vue 2.0中对虚拟DOM的支持。我们可以通过JavaScript动态的创建元素,而不用在template中写HTML代码。虚拟DOM最终将被渲染为真正的DOM。
data: { msg: 'Hello world' }, render (h) { return h( 'div', { attrs: { id: 'my-id' }, [ this.msg ] ); }
渲染后的内容为:
<div id='my-id'>Hello world</div>
Vue 2.0中的render为我们开启了一片新的天地,赋予了我们无限的想象力。比如,我们可以把React中用到的JSX语法应用到Vue中来。接下来,我们就聊聊怎么在Vue项目中使用JSX.
JSX简介
JSX是基于Javascript的语言扩展, 它允许在Javascript代码中插入XML语法风格的代码。如下所示:
data: { msg: 'Hello world' }, render (h) { return ( <div id='my-id'>, { this.msg } </div> ); }
但值得注意的是,浏览器默认是解析不了JSX的,它必须要先编译成标准的JavaScript代码才可以运行。就像我们需要将sass或者less编译为CSS代码之后才能运行一样。
在Vue中使用JSX
Vue框架并没有特意地去支持JSX,其实它也没必要去支持,因为JSX最后都会编译为标准的JavaScript代码。既然这样, 那Vue和JSX为什么能配合在一起使用呢? 很简单, 因为Vue支持虚拟DOM, 你可以用JSX或者其他预处理语言,只要能保证render方法正常工作即可。
Vue官方提供了一个叫做babel-plugin-transform-vue-jsx的插件来编译JSX, 我们稍后介绍如何使用它。
为什么要在Vue中使用JSX
为什么要再Vue中使用JSX "htmlcode">
new Vue({ el: '#app', data: { msg: 'Click to see the message' }, methods: { hello () { alert('This is the message') } } });
index.html
<div id="app"> <span class="my-class" style="cursor: pointer" v-on:click="hello" > {{ msg }} </span> </div>
代码很简单,就是在页面上显示一个span, 里面的内容为"Click to see the message"。当点击内容时,弹出一个alert。我们看看用render怎么实现。
用Vue 2.0中的render函数实现
script.js
new Vue({ el: '#app', data: { msg: 'Click to see the message' }, methods: { hello () { alert('This is the message') } }, render (createElement) { return createElement( 'span', { class: { 'my-class': true }, style: { cursor: 'pointer' }, on: { click: this.hello } }, [ this.msg ] ); }, });
index.html
<div id="app"><!--span will render here--></div>
使用JSX来实现
script.js
new Vue({ el: '#app', data: { msg: 'Click to see the message.' }, methods: { hello () { alert('This is the message.') } }, render: function render(h) { return ( <span class={{ 'my-class': true }} style={{ cursor: 'pointer' }} on-click={ this.hello } > { this.msg } </span> ) } });
index.html和上文一样。
babel-plugin-transform-vue-jsx
正如前文所说, JSX是需要编译为JavaScript才可以运行的, 所以第三个样例需要有额外的编译步骤。这里我们用Babel和Webpack来进行编译。
打开你的webpack.config.js文件, 加入babel loader:
loaders: [ { test: /\.js$/, loader: 'babel', exclude: /node_modules/ } ]
新建或者修改你的.babelrc文件,加入 babel-plugin-transform-vue-jsx 这个插件
{ "presets": ["es2015"], "plugins": ["transform-vue-jsx"] }
现在运行webpack, 代码里面的JSX就会被正确的编译为标准的JavaScript代码。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。