微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

颤动将颜色字符串转换为颜色

如何解决颤动将颜色字符串转换为颜色

我有一组来自数据库的数据,就像这样

{
   ...
    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 举报,一经查实,本站将立刻删除。