5

我正在 Dart Web UI 中构建一个简单的网站。每个页面都有一个页眉(带有站点导航)和一个页脚。我为页眉和页脚使用了组件,每个页面看起来像这样:

<!DOCTYPE html>
<html>
<head>
    <title>Test</title>

    <link rel="import" href="header.html">
    <link rel="import" href="footer.html">
</head>

<body>
    <header-component></header-component>

    Page content...

    <footer-component></footer-component>
</body>
</html>

这很好用,但组件不会插入到 HTML 本身,而是从 Dart(或 JavaScript)代码动态加载。有没有办法让 Web UI 编译器将页眉和页脚插入 HTML 文件本身,以便搜索引擎和禁用 JavaScript 的用户可以看到它们?

4

2 回答 2

2

目前,不,这是不可能的。您想要的是这些模板的服务器端呈现,以便您可以在客户端请求您的页面(包括搜索蜘蛛)时直接将它们提供给客户端。

但是,您可能希望跟踪此问题:https ://github.com/dart-lang/web-ui/issues/107?source=c

当它完成时,事情看起来会更好。

于 2013-06-02T22:10:16.137 回答
2

没有直接的方法可以做到这一点。

这通常是服务器端任务:服务器负责生成所需的 HTML。

Web 组件都是关于客户端的,因此它们处理已经交付给浏览器的内容。

但是,build.dart每次项目中的文件更改时都会执行脚本,因此您可以扩展脚本以获得所需的内容。我认为这不是一个好方法,但它可以解决您的问题。

首先将以下占位符添加到目标 html 文件(在我的例子中web/webuitest.html):

<header></header>

现在header.html向您的项目添加一个包含一些内容的文件:

THIS IS A HEADER

现在扩展build.dart脚本,以便检查是否header.html已修改,如果是,它将更新webuitest.html

// if build.dart arguments contain header.html in the list of changed files
if (new Options().arguments.contains('--changed=web/header.html')) {
    // read the target file
    var content = new File('web/webuitest.html').readAsStringSync();
    // read the header
    var hdr = new File('web/header.html').readAsStringSync();
    // now replace the placeholder with the header
    // NOTE: use (.|[\r\n])* to match the newline, as multiLine switch doesn't work as I expect
    content = content.replaceAll(
        new RegExp("<header>(.|[\r\n])*</header>", multiLine:true), 
        '<header>${hdr}</header>');
    // rewrite the target file with modified content
    new File('web/webuitest.html').writeAsStringSync(content);
  }

这种方法的一个后果是重写目标将build.dart再次触发,因此输出文件将被构建两次,但这不是一个大问题。

当然,这可以做得更好,甚至有人可以将其包装到库中。

于 2013-06-02T22:17:53.383 回答