dart - 将网址传递到Dart应用中

标签 dart dart-webui

我有一个带有链接的页面。这些链接都以相同的方式结束。例如www.site.com/fruit/apples, www.site.com/fruit/bananas, www.site.com/fruit/oranges等。我希望所有这些链接调用同一个Dart应用程序,并让该应用程序进行一些处理,然后将您重定向到所需的位置(“香蕉”页面与“橘子”页面)。这样,我避免了每个水果都有一个实际的HTML文件。相反,我可以有一个单独的着陆模板,其中填充了可变的水果数据。

我挂断的部分是将URL传递到Dart应用程序中,以便它可以进行处理。我了解main()无法接收参数,那又是什么呢?

最佳答案

您可以使用route package为您处理URL。

例如:

import 'package:route/client.dart';

final fruitUrl = new UrlPattern(r'/fruit/(\w+)');

main() {
  var router = new Router()
    ..addHandler(fruitUrl, showFruit)
    ..listen();
}

void showFruit(String path) {
  var fruit = fruitUrl.parse(req.path)[0];
  // Display the page according to the fruit type
}

如果您不需要处理实际的路由,而只想处理以?fruit=apple形式传递的任何查询参数,则不必使用路由包,而可以手动解析URL:

Map params = {};

// If arguments were provided, decode them into params map
if(window.location.search.length > 1) {
  // Break all arguments into form: fruit=apple
  List<String> queryPairs = window.location.search.substring(1).split('&');
  for(String queryPair in queryPairs) {
    // Add arguments into params map: key=fruit, value=apple
    List<String> queryPairList = queryPair.split('=');
    params[queryPairList[0]] = queryPairList[1];
  }
}

// Handle the proper action based on the fruit
switch(params['fruit']) {
  case 'apple':
    // ...
    break;
    // ...
  case 'orange':
    // ...
    break;
}

关于dart - 将网址传递到Dart应用中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17223488/

相关文章:

flutter - 小部件重建后显示 snackbar 消息

dart - @observable 是否必须在每个领域都使用?

dart - 如何在 Web UI <select> 标记中设置默认选定选项?

flutter - 如何:在TextFormField中键入时,每4个字符后添加一个空格

dart - 是否有显示表单功能的 dart 教程?

dart - 我们如何在 Dart 中混合流?

string - Wordwrap函数,用于在dart中包装字符串

html - 如何在 Dart 中为网页制作预加载器

dart - 内部错误:…模棱两可的引用: 'DataGrid'在库web/DataGrid.dart和web/out/DataGrid.dart中定义

html - Dart webUI CSS 问题