javascript - 无法在javascript反应中更改警报消息的颜色
问题描述
我正在尝试对警报组件进行编程,但我无法更改警报消息的颜色。
当我在导航栏中启用暗模式时(在导航栏组件代码的最后出现),它将显示一条警报消息,提示启用了暗模式。我正在使用引导 CSS
警报组件:
import React from "react";
export default function Alert(props) {
const capital = (word) => {
const lower = word.toLowerCase();
return lower.charAt(0).toUpperCase() + lower.slice(1);
};
return (
props.alert && (
<div
className={`alert alert-${props.alert.type} alert-dismissible fade show`}
role="alert"
>
<strong>{capital(props.alert.type)}</strong>: {props.alert.msg}
</div>
)
);
}
导航栏组件:
import React from "react";
import PropTypes from "prop-types";
export default function Navbar(props) {
return (
<>
<nav
className={`navbar navbar-expand-lg navbar-${props.mode} bg-${props.mode}`}
>
<div className="container-fluid">
<a className="navbar-brand" href="/">
Navbar
</a>
<div className="collapse navbar-collapse" id="navbarSupportedContent">
<ul className="navbar-nav me-auto mb-2 mb-lg-0">
<li className="nav-item">
<a className="nav-link active" aria-current="page" href="/">
Home
</a>
</li>
<li className="nav-item">
<a className="nav-link" href="/">
Link
</a>
</li>
<li className="nav-item">
<a
className="nav-link "
href="/"
tabIndex="-1"
aria-current="page"
>
{props.aboutText}
</a>
</li>
</ul>
<form className="d-flex mx-2">
<input
className="form-control me-2"
type="search"
placeholder="Search"
aria-label="Search"
/>
<button className="btn btn-outline-success" type="submit">
Search
</button>
</form>
<div
className={`form-check form-switch text-${
props.mode === "light" ? "dark" : "light"
} mx-2`}
>
<input
className="form-check-input "
onClick={props.togglemode}
type="checkbox"
id="flexSwitchCheckDefault"
/>
<label
className={`form-check-label `}
htmlFor="flexSwitchCheckDefault"
>
Enable Dark Mode
</label>
</div>
</div>
</div>
</nav>
</>
);
}
应用程序.js:
import "./App.css";
import Navbar from "./components/Navbar";
import React, { useState } from "react";
import Alert from "./components/Alert";
function App() {
const [mode, setMode] = useState("light");
const [alert, setAlert] = useState(null);
const showAlert = (message, type) => {
setAlert({
msg: message,
type: type,
});
setTimeout(() => {
setAlert(null);
}, 1500);
};
const togglemode = () => {
if (mode === "light") {
setMode("dark");
document.body.style.backgroundColor = "#042743";
showAlert("Dark mode has been enabled", "Success");
} else {
setMode("light");
document.body.style.backgroundColor = "white";
showAlert("Light mode has been enabled", "Success");
}
};
return (
<>
<Navbar aboutText="About Myself" mode={mode} togglemode={togglemode} />
<div className="container " my-3="true">
<Alert alert={alert} />
</div>
</>
);
}
export default App;
解决方案
更改showAlert函数的第二个属性:
从“成功”到“成功”。它会起作用的。
为了让您更轻松,请替换:
showAlert("Dark mode has been enabled", "Success");
与:
showAlert("Dark mode has been enabled", "success");
在切换模式功能的两个地方。
推荐阅读
- reactjs - 尝试从合约 A 部署合约 B,出现错误:无法存储合约代码,请检查您的 gas 限制。?
- list - Tcl 拆分列表中的列表元素
- python - 我无法使用 pywebcopy 下载完整的网页
- typescript - 为什么 Typescript 会为同一个变量推断不同的类型?
- haskell - 声明函数类型时语法不一致
- android - 在 Android 的 Kotlin 中,我需要一个查找表,在运行时从中选择一个数字。如何从资源中获取此表?
- python - 当我输入一个带有数字平方的大表达式时,eval() 函数会停止程序。Python
- spring-boot - 如何在 Jhipster 中使用 Spring 的 RouterFunction
- javascript - 单个字符的宽度是多少?
- windows - 当 expo-webpack 在 Windows 上运行时,如何修复与编辑文件相关的 EPerm 问题