当前位置:Gxlcms > JavaScript > vue jsx 使用指南及vue.js 使用jsx语法的方法

vue jsx 使用指南及vue.js 使用jsx语法的方法

时间:2021-07-01 10:21:17 帮助过:53人阅读

vue  jsx  语法与 react  jsx  还是有些不一样,在这里记录下。

  1. let component = null// if 语句
  2. if (true) {
  3. component = (
  4. <div></div>
  5. );
  6. } else {
  7. component = (
  8. <div></div>
  9. );
  10. }
  11. var ul = (
  12. <ul>
  13. {component}
  14. </ul>
  15. );
  16. // map 语句
  17. var coms = limit.map(i => {
  18. return {
  19. <li>
  20. {ul}
  21. </li>
  22. };
  23. })
  24. // 属性
  25. <li onClick={() => console.log()}>
  26. // 自定义指令
  27. let directives = [{name: 'prod-img', value: params.row.skn, modifiers: {skn: true}} ];
  28. return (
  29. <div>
  30. <img {...{directives}}></img> // 属性展开
  31. </div>
  32. );
  33. // 自定义过滤器
  34. 不建议使用,直接当函数使用
  35. foo(something)
  36. // methods
  37. this.foo()
  38. // model
  39. <i-input
  40. value={params.row.factoryCode}
  41. placeholder='请输入...'
  42. onInput={val => (params.row.factoryCode = val)}
  43. style={{width: '100%'}}>
  44. </i-input>
  45. // 自定义事件
  46. return (
  47. <Operator
  48. category-id={this.categoryId} // prop绑定
  49. product={params.row} // prop 绑定
  50. onChange={this.onChangeStatus}> // event 绑定
  51. </Operator>
  52. );
  53. //三元运算
  54. <div>
  55. <h1>{i == 1 ? 'True!' : 'False'}</h1>
  56. </div
  57. // 注释
  58. <div>
  59. <h1>菜鸟教程</h1>
  60. {/*注释...*/}
  61. </div>
  62. // html
  63. <div>{{_html: '<h1>Hello World!!</h1>'}}</div>
  64. // h函数写法
  65. return h('Input', {
  66. props: {
  67. value: params.row.buyingNums
  68. },
  69. on: {
  70. input: val => {
  71. params.row.buyingNums = val;
  72. },
  73. 'on-blur': () => {
  74. this.update(params);
  75. }
  76. }
  77. });
  78. // 所有的事件监听必须以on开头,然后字母大写
  79. // template
  80. <input @on-change='click'>
  81. // jsx
  82. <input onOn-change={() => this.click()}></input>

好了,下面看下vue.js 使用jsx语法的方法

1、创建一个测试的组件

  1. export default {
  2. name:'Test',
  3. components:{
  4. },
  5. render(h){
  6. return <div>
  7. test
  8. </div>
  9. },
  10. data () {
  11. return {
  12. }
  13. }
  14. }

2、把编辑器js语言的版本设置成jsx,这样编辑器 可以正确识别jsx语法

3、安装npm依赖

  1. babel-plugin-syntax-jsx\
  2. babel-plugin-transform-vue-jsx\
  3. babel-helper-vue-jsx-merge-props\

4、修改 .babelrc

  1. { "presets": ["es2015"], "plugins": ["transform-vue-jsx"]
  2. }

我是下载的vux的模板,修改之后顺利打包jsx格式的文件

总结

以上所述是小编给大家介绍的vue jsx 使用指南及vue.js 使用jsx语法的方法,希望对大家有所帮助!

人气教程排行