gpt4 book ai didi

javascript - Material UI 3.9.3 未在 IE 中设置复选框样式

转载 作者:行者123 更新时间:2023-11-28 13:54:14 25 4
gpt4 key购买 nike

我正在尝试使用 Material-UI v3.9.3's Checkbox 创建自定义同意复选框.

原因:自定义因为,要求是让它具有特定的背景(Checkbox 区域为白色)和前景(check icon 为橙色)颜色。

到目前为止的实现情况:我已经使用自定义 CSS 实现了它。

index.js:

import React, { useState } from "react";
import { render } from "react-dom";
import Hello from "./Hello";
import Checkbox from "@material-ui/core/Checkbox";
import { withStyles, makeStyles } from "@material-ui/styles";

import "./style.css";

const useStyles = makeStyles({
checkbox: {
padding: 0,
width: 24,
height: 24
},
icon: {
borderRadius: 3,
width: 24,
height: 24,
boxShadow: "inset 0 0 0 1px rgba(16,22,26,.2), inset 0 -1px 0 rgba(16,22,26,.1)",
backgroundColor: "#ffffff",
"input:hover ~ &": {
backgroundColor: "#f5f8fa"
},
"input:disabled ~ &": {
boxShadow: "none",
background: "rgba(206,217,224,.5)"
}
},
root: {
background: "linear-gradient(45deg, #FE6B8B 30%, #FF8E53 90%)",
border: 0,
borderRadius: 3,
boxShadow: "0 3px 5px 2px rgba(255, 105, 135, .3)",
color: "white",
height: 48,
padding: "0 30px"
},
checkedIcon: {
borderRadius: 2,
"&:before": {
display: "block",
width: 24,
height: 24,
backgroundImage:
"url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Crect width='23' height='23' x='.5' y='.5' fill='%23FFF' fill-rule='nonzero' stroke='%23999' rx='4'/%3E%3Ctext fill='%23F2410A' font-size='20' font-weight='bold'%3E%3Ctspan x='1' y='18'%3E✓%3C/tspan%3E%3C/text%3E%3C/g%3E%3C/svg%3E%0A\")",
content: '""'
},
"input:hover ~ &": {
backgroundColor: "#106ba3"
}
}
});

const App = props => {
const classes = useStyles();
const [consentGiven, setConsentGiven] = useState(false);
const handleChange = event => {
!consentGiven && setConsentGiven(true);
};

return (
<div>
<Checkbox
className={classes.checkbox}
checked={consentGiven}
color="primary"
onChange={handleChange}
icon={<span className={classes.icon} />}
checkedIcon={<span className={classes.checkedIcon} />}
inputProps={{
"aria-label": "primary checkbox"
}}
/>
</div>
);
};

render(<App />, document.getElementById("root"));

index.html:

<div id="root"></div>

Here's a Sample StackBlitz with the minimal code required to reproduce the issue.

问题:该解决方案似乎在 Chrome 中完美运行。但在 IE 中,一旦用户选中复选框,它就会消失。

预期行为:复选框一旦选中,在 IE 上应保持可见并处于选中状态。

最佳答案

该问题最初由 Alexey Zuev 在推特上回答 Twitter here

只是在这里发布它并附上详细的解释,这样它可能会对某人有所帮助。正如 Alexey 在他的推文中提到的那样:

It's an issue with inlining svg into background css property in IE.

Just follow this answer Inline SVG in CSS and you will be able to fix the issue like here

At least it works in Edge :)

修复

  1. 我去了 https://mothereff.in/url并将 url 编码的 svg 字符串粘贴到那里:

    输入:

    "url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Crect width='23' height='23' x='.5' y='.5' fill='%23FFF' fill-rule='nonzero' stroke='%23999' rx='4'/%3E%3Ctext fill='%23F2410A' font-size='20' font-weight='bold'%3E%3Ctspan x='1' y='18'%3E✓%3C/tspan%3E%3C/text%3E%3C/g%3E%3C/svg%3E%0A\")"

    输出:

    "url(\"data:image/svg xml,<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><g fill='none' fill-rule='evenodd'><rect width='23' height='23' x='.5' y='.5' fill='#FFF' fill-rule='nonzero' stroke='#999' rx='4'/><text fill='#F2410A' font-size='20' font-weight='bold'><tspan x='1' y='18'>✓</tspan></text></g></svg>
    \")"
  2. 获取生成的 svg(从 <svg</svg> )并使用 btoa 将 svg 编码为 Base64。这样做时,您会收到一条错误消息:

    VM116:1 Uncaught DOMException: Failed to execute 'btoa' on 'Window': The string to be encoded contains characters outside of the Latin1 range.

    现在的原因是因为我们在 中有这个刻度符号 ( svg ) .因此,我们首先需要将其转换为扩展的特殊 HTML 代码,对于 标志,是&#10004; ( Source )

  3. 现在我们有一个 svg可以正确编码,看起来像这样:

    <svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><g fill='none' fill-rule='evenodd'><rect width='23' height='23' x='.5' y='.5' fill='#FFF' fill-rule='nonzero' stroke='#999' rx='4'/><text fill='#F2410A' font-size='20' font-weight='bold'><tspan x='1' y='18'>&#10004;</tspan></text></g></svg>

    我们可以通过 btoa 传递它生成 Base64 编码的字符串:

    const base64UrlString = btoa("<svg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'><g fill='none' fill-rule='evenodd'><rect width='23' height='23' x='.5' y='.5' fill='#FFF' fill-rule='nonzero' stroke='#999' rx='4'/><text fill='#F2410A' font-size='20' font-weight='bold'><tspan x='1' y='18'>&#10004;</tspan></text></g></svg>");

    console.log('Here is the generated Base64 Encoded String: ', base64UrlString);

  4. 最后,代替内联 svg我们之前使用的,我们现在可以使用 Base64 编码字符串:

    backgroundImage: "url(\"\")",

    它也应该在 IE 中正确呈现。

Here's a Working Code Sample on StackBlitz for your ref.

关于javascript - Material UI 3.9.3 未在 IE 中设置复选框样式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59024659/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com