React碰到v-if的示例分析
发表于:2025-01-24 作者:千家信息网编辑
千家信息网最后更新 2025年01月24日,这篇文章将为大家详细讲解有关React碰到v-if的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。代码:import React from 'react'c
千家信息网最后更新 2025年01月24日React碰到v-if的示例分析
这篇文章将为大家详细讲解有关React碰到v-if的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
代码:
import React from 'react'const App = () => { const record = { toKe: true, // 贝壳首页 toSecondHand: true, // 二手房 toFang: true, // 新房 } return ( )}export default App
如上述代码,我们在项目中会遇到很多这样的写法, 细看一下没什么问题,可是当在重构老项目的时候,你会发现这个代码结构是多么痛苦,特别是如下的结构。
{ record.toFang && record.toKe && record.toSecondHand && }
虽然代码逻辑没问题,但人生就是这样,有时候出场顺序真的很重要。突然就想起vue的v-if了。
没错,回归主题,就是:react中模拟vue的v-if
先上代码
import React from 'react'import Hidden from './Hidden'const App = () => { const record = { toKe: true, // 贝壳首页 toSecondHand: true, // 二手房 toFang: true, // 新房 } return ( )}export default App
简单就是封装Hidden组件,通过visible去控制是否渲染。
相信聪明的你一定知道怎么去封装Hidden
笔者刚开始是这么写的
import React, { Component } from 'react'export default class Hidden extends Component { render() { const { visible, children } = this.props const content = visible ? children : null return ({ content }) }}
如此简单,但笔者审查元素的时候发现,每个Hidden下的children莫名被嵌套了一层div
如下
原来的横着排列的元素,一下子竖着排列了。这可不太好,本来给我套个div,我都可以勉强接收,现在连我布局都给我变了。
怎么办?笔者突然想到使用vue-router中的router-link时,标签是可以通过tag去替换默认标签的。
那我们再给它个tag呗,连带自定义属性。
import React, { Component } from 'react'export default class Hidden extends Component { render() { const { visible, children, tag = 'div', ...rest } = this.props const content = visible ? children : null return ( React.createElement(tag, rest, content) ) // return ( // 尝试用这种方法去实现,发现不符合react的规则,所以使用最原始的渲染方法 // React.createElement // `<`${tag}`>` + { content } + ``${tag}`>` // ) }}
问题:笔者的初衷是模拟vue的v-if, 所以对传入的children并没做太多处理,不建议做多做封装。有兴趣的同学可以自己玩。
{ record.toFang && record.toKe && record.toSecondHand && 贝壳首页 二手房 新房 }a href="https://bj.ke.com" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >贝壳首页 二手房 新房
其实感觉也没多大用处hhhh
关于"React碰到v-if的示例分析"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
二手房
新房
贝壳
首页
代码
笔者
就是
篇文章
问题
封装
示例
分析
元素
写法
方法
时候
更多
标签
结构
项目
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
湖南信息化软件开发过程服务标准
unity资源服务器
政府关于网络安全的部门
联运专区最新服务器
服务器ip如何修复
淄博智能软件开发
曙光服务器西安电话
梦幻西游网页版s开头的服务器
户口迁移软件开发
数据库中dom是什么意思
华为 服务器 400
sybase数据库cmd
佛山通讯软件开发价目表
insert批量插数据库
网络安全宣传周主要内容是
山西三盛网络技术有限公司
宁波青枫互联网科技有限公司
数据库查看日志的基本命令
诛仙3服务器颜色
施乐700打印服务器
数据库建设时
数据库的数据源怎么用文档来获取
我的世界1.18服务器开荒
网络安全宣传微视频小学生
服务器出售发卡网
区块链网络技术与应用论文
网络安全架构前言
怎么成为一个数据库管理员
网络安全视频幼儿知识
万得免费数据库