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

Dart 从 URL 字符串中提取主机 提取二级域名

如何解决Dart 从 URL 字符串中提取主机 提取二级域名

假设我有以下 URL 作为字符串;

  Widget textField() {
    return TextField(
      enabled: false,decoration: Inputdecoration(
          contentPadding: EdgeInsets.symmetric(vertical: 10.0),focusedBorder: OutlineInputBorder(
            borderSide: BorderSide(color: Colors.transparent),borderRadius: BorderRadius.circular(10.0),),border: OutlineInputBorder(
            borderSide: BorderSide(color: Colors.white),borderRadius: BorderRadius.all(
              Radius.circular(10.0),hintStyle: TextStyle(
              fontSize: 18,color: Theme.of(context).secondaryHeaderColor),hintText: 'Search',prefixIcon: Padding(
            padding: EdgeInsets.all(2),child: SizedBox(
              width: 10,height: 10,child: Image.asset(
                'assets/icons/nav-icons/Explore.png',suffixIcon:
              Icon(Icons.mic,filled: true,fillColor: Theme.of(context).primaryColor),);
  }
  

我想从这个url字符串中提取主页名称; 'wikipedia',从网址中删除 https://www.com.org 部分。

提取内容的最佳方法是什么?对于RegExp,我必须使用什么正则表达式?

解决方法

在这种情况下,您不需要使用 RegExp

Dart 有一个用于解析 URL 的预制类:

Uri

使用该 API,您想要实现的目标非常简单:

final urlSource = 'https://www.wikipedia.org/';

final uri = Uri.parse(urlSource);
uri.host; // www.wikipedia.org

Uri.host property 会给你 www.wikipedia.org。从那里,您应该能够轻松提取 wikipedia

Uri.host 还将删除整个路径,即主机后 / 之后的任何内容。

提取二级域名

如果您想从主机获取 second-level domain,即 wikipedia,您可以执行 uri.host.split('.')[uri.host.split('.').length - 2]

但是,请注意这不是万无一失的,因为您可能有或没有子域(例如 www),并且顶级域也可能由多个部分组成。例如,co.uk 使用 co 作为二级域。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?