2024-06-18 11:27AM
参考:https://legacy.reactjs.org/docs/conditional-rendering.html
在React中,可以创建不同的组件来封装所需的行为。然后,可以仅渲染其中的一些,具体取决于应用程序的状态。
React中的条件渲染的工作方式与JavaScript中条件的工作方式相同。
使用JavaScript运算符,例如:if或条件(三元)运算符来创建表示当前状态的元素
考虑这两个组件:
function UserGreeting(props) {
  return <h1>Welcome bacak!</h1>;
}
function GuestGreeting(props) {
  return <h1>Please sign up.</h1>;
}
我们将创建一个Greeting根据用户是否登录显示以下组件之一的组件:
function Greeting(props) {
  const isLoggedIn = props.isLoggedIn;
  if (isLoggedIn) {
    return <UserGreeting />;
  }
  return <GuestGreeting />;
}
const root = ReactDOM.createRoot(document.getElementById('root')); 
// Try changing to isLoggedIn={true}:
root.render(<Greeting isLoggedIn={false} />); 
Greeting文件整体代码如下:
import React from 'react';
import ReactDOM from 'react-dom/client';
function UserGreeting(props) {
  return <h1>Welcome bacak!</h1>;
}
function GuestGreeting(props) {
  return <h1>Please sign up.</h1>;
}
function Greeting(props) {
  const isLoggedIn = props.isLoggedIn;
  if (isLoggedIn) {
    return <UserGreeting />; //true
  }
  return <GuestGreeting />; //false
}
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<Greeting isLoggedIn={false} />);
export default Greeting;
页面显示情况如下:
 
 
上面这个示例可以根据isLoggedIn prop的值呈现不同的问候语
元素变量
我们可以使用变量来存储元素,这可以帮助我们有条件地渲染组件的一部分,而输出的其余部分不变。
考虑这两个表示“注销”和“登录”按钮的新组件:
function LoginButton(props) {
  return (
    <button onClick={props.onClick}>
      Login
    </button>
  );
}
function LogoutButton(props) {
  return (
    <button onClick={props.onClick}>
      Logout
    </button>
  );
}
下面的例子中,我们将创建一个名为LoginControl的有状态组件
它将呈现<LoginButton />或者<LogoutButton />取决于其当前状态。它还会渲染一个<Greeting />从前面的例子来看:
class LoginControl extends React.Component {
  constructor(props) {
    super(props);
    this.handleLoginClick = this.handleLoginClick.bind(this);
    this.handleLogoutClick = this.handleLogoutClick.bind(this);
    this.state = {isLoggedIn: false};
  }
  handleLoginClick() {
    this.setState({isLoggedIn: true});
  }
  handleLogoutClick() {
    this.setState({isLoggedIn: false});
  }
  render() {
    const isLoggedIn = this.state.isLoggedIn;
    let button;
    if (isLoggedIn) {
      button = <LogoutButton onClick={this.handleLogoutClick} />;
    } else {
      button = <LoginButton onClick={this.handleLoginClick} />;
    }
    return (
      <div>
        <Greeting isLoggedIn={isLoggedIn} />
        {button}
      </div>
    );
  }
}
const root = ReactDOM.createRoot(document.getElementById('root')); 
root.render(<LoginControl />);
LoginControl文件整体代码内容如下:
import React from 'react';
import ReactDOM from 'react-dom/client';
function Greeting(props) {
  const isLoggedIn = props.isLoggedIn;
  if (isLoggedIn) {
    return <h1>Welcome back!</h1>;
  }
  return <h1>Please sign up.</h1>;
}
function LoginButton(props) {
  return (
    <button onClick={props.onClick}>
      Login
    </button>
  );
}
function LogoutButton(props) {
  return (
    <button onClick={props.onClick}>
      Logout
    </button>
  );
}
class LoginControl extends React.Component {
  constructor(props) {
    super(props);
    this.handleLoginClick = this.handleLoginClick.bind(this);
    this.handleLogoutClick = this.handleLogoutClick.bind(this);
    this.state = {isLoggedIn: false};
  }
  handleLoginClick() {
    this.setState({isLoggedIn: true});
  }
  handleLogoutClick() {
    this.setState({isLoggedIn: false});
  }
  render() {
    const isLoggedIn = this.state.isLoggedIn;
    let button;
    if (isLoggedIn) {
      button = <LogoutButton onClick={this.handleLogoutClick} />;
    } else {
      button = <LoginButton onClick={this.handleLoginClick} />;
    }
    return (
      <div>
        <Greeting isLoggedIn={isLoggedIn} />
        {button}
      </div>
    );
  }
}
const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<LoginControl />);
export default LoginControl;
页面显示情况如下:
默认页面内容:

点击Login之后,页面内容:

登录
请登录后再发表评论。
评论列表:
目前还没有人发表评论