Vue如何支持JSX语法

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

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

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


1.传统的createElement方法

createElement(

'anchored-heading', {

props: {

level: 1

}

}, [

createElement('span', 'Hello'),

' world!'

]

)

 

 

渲染成下面这样

  Hello world!

 


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

bar

}

})

 

将 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 (
					
{this.handleEdit(1, row)}}> 查看 {this.turnTo(path, row)}}> {name}
); }

写法注意:

1.只能一个根节点 return (

    ...   
  )

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

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

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

你可能感兴趣的:(VUE,vue,jsx)