vue如何使用jsx编写函数式组件?

文章所有的代码是基于Vue CLI 3.x版本,不会涉及到一步步通过Webpack来配置JSX所需要的知识点。

注意: 如果是手动搭建的项目,需要通过安装插件才可使用JSX。

vue如何使用jsx编写

1.创建Test.jsx文件

export default {
  render() {
    return (
      <div>
        <p>vue 使用 jsx</p>
      </div>
    );
  },
};

如此就是最简易版的.jsx文件了

2.插值

在JSX中使用{}来绑定内容

export default {
  data() {
    return {
      val: "这里进行变量存储",
    };
  },
  render() {
    const { val } = this;
    return (
      <div>
        <p>vue 使用 jsx</p>
        {val}
      </div>
    );
  },
};

建议的写法就是在render中解构出来data里的变量,正文里使用即可。

当然,也可直接调用,方法如下:

<p>{this.val}</p>

3.遍历渲染 、 条件渲染

export default {
  data() {
    return {
      val: "这里进行变量存储",
      list: [
        {
          id: 1,
          name: "张三",
        },
        {
          id: 2,
          name: "张四",
        },
        {
          id: 3,
          name: "张五",
        },
        {
          id: 4,
          name: "张六",
        },
      ],
      isShow: true,
    };
  },
  render() {
    const { val, list, isShow } = this;
    return (
      <div>
        <p>vue 使用 jsx</p>
        {/* 插值 */}
        {val}

        <ul>
          {/* 遍历渲染 */}
          {list.map((item, index) => {
            return <li key={item.id}>{item.name}</li>;
          })}
        </ul>

        {/* 条件渲染 */}
        {/* 1. &&  */}
        {isShow && <div>这里是条件渲染</div>}

        {/* 2. 三元运算 */}
        {isShow ? "条件为真显示内容" : "条件为假显示内容"}
      </div>
    );
  },
};

jsx中没有v-ifv-for
条件渲染使用&&或者 三元运算
遍历渲染使用 .map
注意: map的返回值需要是一个标签,且为唯一根标签形式的。遍历出的标签,建议添加key

4. jsx样式添加

推荐使用scss
使用如下:

1.新建styld.scss文件
可根据需求自行编写

.container{
    border: 1px dotted red;
    color: red;
}
ul{
    li{
        line-height: 44px;
        border-bottom: 1px dotted gold;
    }
}

2.在当前.jsx内引入使用

import './styled.scss' // 引入外部样式
export default {
  data() {
    return {
      val: "这里进行变量存储",
      list: [
        {
          id: 1,
          name: "张三",
        },
        {
          id: 2,
          name: "张四",
        },
        {
          id: 3,
          name: "张五",
        },
        {
          id: 4,
          name: "张六",
        },
      ],
      isShow: true,
    };
  },
  render() {
    const { val, list, isShow } = this;
    return (
    // 添加class 此处与react不一样,不需使用className,因为在react中class为关键字
      <div class='container'>
        <p>vue 使用 jsx</p>
        {/* 插值 */}
        {val}

        <ul>
          {/* 遍历渲染 */}
          {list.map((item, index) => {
            return <li key={item.id}>{item.name}</li>;
          })}
        </ul>

        {/* 条件渲染 */}
        {/* 1. &&  */}
        {isShow && <div>这里是条件渲染</div>}

        {/* 2. 三元运算 */}
        {isShow ? "条件为真显示内容" : "条件为假显示内容"}
      </div>
    );
  },
};

5. 使用自定义组件

当组件仅需要展示,而不需要进行其他操作时,不用维护状态,可使用 functional进行标识,性能会好很多

1.创建组件
Child1.jsx
// 仅进行展示

export default {
  functional: true,
  render(h, content) {
    console.log("content", content);
    return <div>这里是子组件,展示的内容为:{content.props.val}</div>;
  },
};

注意: 函数式组件是没有this的。所有的内容都在render的第二个参数

Child2.jsx
// 调用父组件方法,修改child1显示的内容

export default {
  functional: true,
  render(h, content) {
    return (
      <div>
        <p>这里是子组件2</p>
        {/* 绑定事件 需要加on */}
        {/* 调用父组件方法 也是在 content里进行调用,因为没有this*/}
        <button onClick={() => content.listeners.parent()}>
          click me,调用父组件方法
        </button>
      </div>
    );
  },
};

2.父组件使用

import "./styled.scss";
import Child1 from "./Child1";
import Child2 from "./Child2";
export default {
  components: ["Child1", "Child2"],
  data() {
    return {
      val: "这里进行变量存储",
      list: [
        {
          id: 1,
          name: "张三",
        },
        {
          id: 2,
          name: "张四",
        },
        {
          id: 3,
          name: "张五",
        },
        {
          id: 4,
          name: "张六",
        },
      ],
      isShow: true,
      childMsg: "父组件传递给子组件的内容",
    };
  },
  methods: {
    // 定一个一个方法,修改数据
    changeMsg() {
      this.childMsg = "点击了child2,修改了child1的内容";
    },
  },
  render() {
    const { val, list, isShow, childMsg } = this;
    return (
      // 添加class 此处与react不一样,不需使用className
      <div class="container">
        <p>vue 使用 jsx</p>
        {/* 插值 */}
        {val}

        <ul>
          {/* 遍历渲染 */}
          {list.map((item, index) => {
            return <li key={item.id}>{item.name}</li>;
          })}
        </ul>

        {/* 条件渲染 */}
        {/* 1. &&  */}
        {isShow && <div>这里是条件渲染</div>}

        {/* 2. 三元运算 */}
        {isShow ? "条件为真显示内容" : "条件为假显示内容"}

        {/* 调用子组件 */}
        {/* child1 仅仅展示数据 */}
        <Child1 val={childMsg} />

        {/* Child2 调用父组件方法 */}
        {/* 注意: 此处使用on绑定方法parent,子组件只需调用parent方法 */}
        <Child2 onparent={() => this.changeMsg()} />
      </div>
    );
  },
};

jsx组件内content的内容有很多,简单说一哈:

children        # VNode数组,类似于React的children
data          # 绑定的属性
    attrs       # Attribute
    domProps    # DOM property
    on                # 事件
injections  # 注入的对象
listeners:  # 绑定的事件类型
    click         # 点击事件
    ...
parent            # 父组件
props                # 属性
scopedSlots # 对象,作用域插槽,使用中发现作用域插槽也挂在这个下面
slots                # 函数,插槽

如此就可进行业务代码简单的编写了。。。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue2中使用JSX编写组件是一种替代模板语法的方法。使用JSX可以更直观地描述组件结构和逻辑,使代码更加可读性和可维护性。可以通过配置Babel插件来实现将JSX转译为render函数渲染。 下面是一个使用JSX编写Vue2组件的示例: ```jsx export default { name: 'MyComponent', data() { return { options: [ { value: 'option1', label: 'Option 1' }, { value: 'option2', label: 'Option 2' }, { value: 'option3', label: 'Option 3' } ], selectedOption: '' } }, render() { return ( <div class="my-component"> {this.options.map(option => ( <div key={option.value} class={option.value === this.selectedOption ? 'selected' : ''} onClick={() => (this.selectedOption = option.value)} > {option.label} </div> ))} </div> ) } } ``` 在上面的示例中,我们使用JSX语法来描述组件的结构,通过render函数JSX转译为渲染函数。可以看到,使用JSX可以更直观地创建组件,并且可以通过JSX语法来处理组件的交互逻辑。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue+jsx函数组件](https://blog.csdn.net/weixin_41923266/article/details/126661795)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue组件jsx语法的具体使用](https://download.csdn.net/download/weixin_38607908/13207182)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值