介绍

通常开发vue我们使用的是模板语法,其实还有和react相同的语法,那就是render函数,同样支持jsx语法。
Vue 的模板实际是编译成了 render 函数。
以下是普遍的说明文档,文末是作者的示例。
参考文献:vue.js官网

传统的createElement方法

createElement(
 'anchored-heading', {
  props: {level: 1}
}, [createElement('span','Hello'), 'world!'])

渲染成下面这样

<anchored-heading :level="1">

  <span>Hello</span> world!

</anchored-heading>

使用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 (
    )
  2. 事件绑定on-click={()=>{ … }}
  3. 变量写入html {变量名} //如文章中name 变量
  4. 变量计算属性{变量名} //如文章中disabled变量
    转至目录
Logo

前往低代码交流专区

更多推荐