Vue如何支持JSX语法

通常开发vue我们使用的是模板语法,其实还有和react相同的语法,那就是render函数,同样支持jsx语法。 

Vue 的模板实际是编译成了 render 函数。

以下是普遍的说明文档,文末是作者的示例。


1.传统的createElement方法

createElement(

'anchored-heading', {

props: {

level: 1

}

}, [

createElement('span', 'Hello'),

' world!'

]

)

 

 

渲染成下面这样

<anchored-heading :level="1">

  <span>Hello</span> world!

</anchored-heading>

 


2.使用jsx语法

这就是会用到一个 Babel plugin 插件,用于在 Vue 中使用 JSX 语法的原因,它可以让我们回到于更接近模板的语法上。

1.安装

npm install\

babel-plugin-syntax-jsx\

babel-plugin-transform-vue-jsx\

babel-helper-vue-jsx-merge-props\

babel-preset-es2015\

--save-dev

 

2.编辑.babelrc文件

{

"presets": ["es2015"],  //似乎可以不添加。

"plugins": ["transform-vue-jsx"]

}

 

代码编辑如下

Vue.component('jsx-example', {

render (h) { // <-- h must be in scope

return <div id="foo">bar</div>

}

})

 

将 h 作为 createElement 的别名是 Vue 生态系统中的一个通用惯例,实际上也是 JSX 所要求的,如果在作用域中 h 失去作用, 在应用中会触发报错。

使用示例:

control(row,ele){
				let path = "";
				let name ="";
				let turnTo = true;
				
				switch(row.state_Name){
					case "未提交":
						path="ForestDesign";
						name="转至提交";
					break;
					case "已退回":
					path="ForestDesign";
					name="转至提交";
					break;
					case "审核中":
					path="ForestApproval";
					name="转至审核";
					break;
					case "待验收":
					path="ForestAccept";
					name="转至验收";
					break;
					case "待核查":
					path="ForestCheck";
					name="转至核查";
					break;
					case "已结项":
					path=" ";
					name="转至...";
					turnTo = false;
					break;
					
				}
				return (
					<div>
						<el-button  type="text" icon="fa fa-eye" on-click={()=>{this.handleEdit(1, row)}}>&nbsp;查看</el-button>
						<el-button type="text" 
						disabled = {!turnTo}
						icon="fa fa-hand-o-right" on-click={()=>{this.turnTo(path, row)}}>&nbsp;{name}</el-button>
					</div>
					
					);
			}

写法注意:

1.只能一个根节点 return ( <div>    ...   </div>  )

2.事件绑定on-click={()=>{   .... }}

3.变量写入html {变量名} //如文章中name 变量

4.变量计算属性{变量名}  //如文章中disabled变量

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值