如何解决颤动将颜色字符串转换为颜色
{
...
name:"any name",something:{
color:"red"
}
}
基于此(无法更改 DB ),如何在具有背景颜色的小部件中动态显示名称,例如 "red"
(取一个颜色字符串red转换为Color类型)
解决方法
据我所知,这是不可能的。
但你可以这样做:
Map<String,Color> nameToColor = {
'red' : Colors.red,'blue' : Colors.blue,}
然后
{
...
name:"any name",something:{
color: nameToColor['red'] ?? Color.green //or any other default color
}
}
,
其实没有这个办法。但是如果颜色的值是已知的,那么我们可以做这样的事情
<link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
<link rel="stylesheet" href="/resources/demos/style.css">
<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
<div id="div">
</div>
像这样使用
Map<String,dynamic> map = {
"name": "any name","something": {"color": "red"}
};
Color getColor(String color) {
switch (color) {
//add more color as your wish
case "red":
return Colors.red;
case "blue":
return Colors.blue;
case "yellow":
return Colors.yellow;
case "orange":
return Colors.orange;
case "green":
return Colors.green;
default:
return Colors.transparent;
}
}
,
你可以输入variable
然后你就可以使用它了。
示例:
const Color Red=Colors.red;
{
...
name:"any name",something:{
color:Red
}
}
,
感谢@Tipu Sultan 和@Er1。
我尝试了另一种解决方案,效果很好
Map<String,dynamic> objFormDB= {
"name": "any name","something": {"color": "red"}
};
Map<String,}
我尝试使用文本小部件
Text( objFormDB.name,style: TextStyle( color : nameToColor[ objFormDB.somethimg.color] )
)
这很简单:)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。