vue.js如何使用jsx语法
短信预约 -IT技能 免费直播动态提醒
这篇文章将为大家详细讲解有关vue.js如何使用jsx语法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
vue jsx 语法与 react jsx 还是有些不一样,在这里记录下。
let component = null// if 语句
if (true) {
component = (
<div></div>
);
} else {
component = (
<div></div>
);
}
var ul = (
<ul>
{component}
</ul>
);
// map 语句
var coms = limit.map(i => {
return {
<li>
{ul}
</li>
};
})
// 属性
<li onClick={() => console.log()}>
// 自定义指令
let directives = [{name: 'prod-img', value: params.row.skn, modifiers: {skn: true}} ];
return (
<div>
<img {...{directives}}></img> // 属性展开
</div>
);
// 自定义过滤器
不建议使用,直接当函数使用
foo(something)
// methods
this.foo()
// model
<i-input
value={params.row.factoryCode}
placeholder='请输入...'
onInput={val => (params.row.factoryCode = val)}
style={{width: '100%'}}>
</i-input>
// 自定义事件
return (
<Operator
category-id={this.categoryId} // prop绑定
product={params.row} // prop 绑定
onChange={this.onChangeStatus}> // event 绑定
</Operator>
);
//三元运算
<div>
<h2>{i == 1 ? 'True!' : 'False'}</h2>
</div
// 注释
<div>
<h2>菜鸟教程</h2>
{}
</div>
// html
<div>{{_html: '<h2>Hello World!!</h2>'}}</div>
// h函数写法
return h('Input', {
props: {
value: params.row.buyingNums
},
on: {
input: val => {
params.row.buyingNums = val;
},
'on-blur': () => {
this.update(params);
}
}
});
// 所有的事件监听必须以on开头,然后字母大写
// template
<input @on-change='click'>
// jsx
<input onOn-change={() => this.click()}></input>
好了,下面看下vue.js 使用jsx语法的方法
1、创建一个测试的组件
export default {
name:'Test',
components:{
},
render(h){
return <div>
test
</div>
},
data () {
return {
}
}
}
2、把编辑器js语言的版本设置成jsx,这样编辑器 可以正确识别jsx语法
3、安装npm依赖
babel-plugin-syntax-jsx\
babel-plugin-transform-vue-jsx\
babel-helper-vue-jsx-merge-props\
4、修改 .babelrc
{ "presets": ["es2015"], "plugins": ["transform-vue-jsx"]
}
我是下载的vux的模板,修改之后顺利打包jsx格式的文件
关于“vue.js如何使用jsx语法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341