首页 > 其他分享 >TreeSaver 使用教程整理——Step 1: Getting Started

TreeSaver 使用教程整理——Step 1: Getting Started

时间:2023-06-27 20:00:52浏览次数:53  
标签:0.9 文件 Getting Started 标签 Treesaver TreeSaver html treesaver

TreeSaver 介绍

Treesaver 是一个开源的JavaScript 框架,用来创建杂志风格的网页布局。

 

为何要整理这个系列的文章

下面的教程整理自: https://github.com/Treesaver/treesaver/wiki/Walkthrough , 也许是这个框架目前才刚刚起步,它的文档很成问题,文档中一些链接不能下载,源代码中欠缺一些必要的内容,导致源代码的例子无法运行等等。我在摸索这个框架时碰了很多弯路,整理这篇文档,就是为了避免后来人也碰弯路。

 


环境准备

1、下载 treesaver-0.9.2.js

TreeSaver 使用了Google的 Closure 工具包,这让我们编译TreeSaver的源码造成了很大复杂性,我就在这里花费了大量时间,结果还是没有弄好它的环境。

这里我们简单起见,先只用它预先编译好的脚本库,这个脚本库下载地址如下:
https://github.com/treesaver/treesaver/downloads

TreeSaver 使用教程整理——Step 1: Getting Started_HTML5

 

如上图所示, treesaver-0.9.2.js 是运行版本,treesaver.js 是带调试信息和注释的。按需下载你所需要的版本。这里我们使用的是:treesaver-0.9.2.js

为了随后演示的方便,我们的目录组织如下:

[Treesaver Walkthrough Directory]
|- treesaver-0.9.2.js
|- img/
|- step1/
|- step2/
   ...

treesaver-0.9.2.js 文件和通用图片目录我们放在外层,

每一步的演示我们一个目录存放对应的一些文件;这个目录一般会有下面三个文件:

  • 文章内容文件,我们一般是 Index.html 文件;
  • 定义布局的资源文件: resources.html
  • 定义样式的样式文件: style.css

 

本文演示的是最简单TreeSaver的搭配,所以本文演示并没有通用图片。即上面的 img 目录是空的

 

index.html 文件的内容:

<!doctype html>
<html class="no-js no-treesaver">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width,height=device-height,initial-scale=1,minimum-scale=1,maximum-scale=1">
    <title>Sample Treesaver Page</title>
    <link rel="stylesheet" href="style.css">
    <link rel="resources" href="resources.html">
    <script src="../treesaver-0.9.2.js"></script>
  </head>
  <body>
    <article>
      <p>This markup is an example of a page using Treesaver for layout. It is not very exciting right now.</p>
    </article>
  </body>
</html>

说明:

  • 确保 Treesaver 的 <script> 标签是在Treesaver的资源文件和样式文件之后。这么做是为了确保IE8能妥善的处理好HTML5的标签。此外这点也可以在脚本和资源文件下载上让用户体验比较好。
    Make sure the Treesaver <script> tag is the final element in the <head>, after the link to the Resources file and any stylesheets. This is required in order to ensure the IE8 and below properly process HTML5 tags. Additionally, this improves the user experience by letting the library download scripts in resources in parallel.
    即注意如下的先后顺序:
  • <link rel="stylesheet" href="style.css">
  • <link rel="resources" href="resources.html">
  • <script src="../treesaver-0.9.2.js"></script>
  • 不要删除<meta name="viewport">标签,如果删除了,你在iPhone和Android上会看到比较怪异的结果。
    Do not remove the <meta name="viewport">, otherwise you will end up with very strange results on iPhone and Android
  • 最好使用HTML5 doctype定义:
    Always Declare the HTML5 doctype: The XHTML doctype is also usable, as long as Quirks mode processing is not triggered
  • 把我们的内容放在<article>标签之内,任何这个标签之外的都将被忽视,在最终显示上都将被删除。如果你的浏览器是不支持的旧浏览器,则可以借用这个特性来实现兼容旧浏览器。
    Place content within an <article> tag: Any content outside the tag is ignored, and will be completely removed when performing layout. You can use that in order to present to content to older browsers, if desired (see Content Format for alternatives).

 


resources.html 文件的内容:

<!doctype html>
<html>
  <body>
    <div class="chrome">
      <div class="viewer"></div>
    </div>
    <div class="grid">
      <div class="column"></div>
    </div>
    <div class="loading">
      Loading
    </div>
    <div class="error">
      Error
    </div>
  </body>
</html>

说明:

  • <head>, <title> 等其他内容标签在模板文件上是可选的,Treesaver 不使用这些标签,你可以省略他们.
    <head>, <title> and other contents are optional. They are not used by Treesaver and can be omitted completely.
     

style.css 文件的内容:

.treesaver body {
  /* Hide scrollbars */
  overflow: hidden;
  /* Use full body canvas */
  margin: 0;
  border: 0;
  padding: 0;
}
.chrome, .viewer, .grid, .column, .container {
  /* Manually position everything */
  position: absolute;
  /* Make sure seams aren't visible */
  overflow: hidden;
  /* Set the base vertical grid */
  line-height: 20px;
}
/* Stretch the viewer to fill the screen */
.viewer {
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
.grid {
  width: 300px;
  border: 1px solid #ccc;
  margin: 9px;
}
.column {
  width: 280px;
  top: 5px;
  bottom: 5px;
  left: 5px;
}

说明:

  • 这是一个非常简单丑露的样式, 这只是我们学习 treesaver的出发点。
    This is a bare-bones starting point, it will look quite ugly

 

上面演示的效果:

TreeSaver 使用教程整理——Step 1: Getting Started_css_02

这里我们把 index.html 文件的内容放的很少,就是上面的效果。

如果我们把index.html文件的内容放多一些,比如我们把下面这篇英文小说其中几段放入: http://www.gutenberg.org/files/11/11-h/11-h.htm 就会看到如下效果:

TreeSaver 使用教程整理——Step 1: Getting Started_css_03

这里使用英文小说,是为了避免编码问题导致乱码的情况。

 

中文乱码的问题

如果我们没做一些处理,我们把中文文章放入其中,显示的效果如下,乱码:

TreeSaver 使用教程整理——Step 1: Getting Started_HTML5_04

解决方法,我们用记事本打开step目录下的内容文件,把它的编码修改为UTF-8即可:

TreeSaver 使用教程整理——Step 1: Getting Started_html_05

 

参考资料:

https://github.com/Treesaver/treesaver/wiki/Boilerplate

https://github.com/Treesaver/treesaver/wiki/Walkthrough

标签:0.9,文件,Getting,Started,标签,Treesaver,TreeSaver,html,treesaver
From: https://blog.51cto.com/u_15588078/6565328

相关文章

  • TreeSaver.js 的工作流程逻辑
    Treesaver是浏览器大小尺寸敏感(size-sensitive)的,会就着当前的浏览器尺寸(browsersize),选用不同的分栏表格(grid)做排版。初始化TreeSaver.js框架的入口源代码在后面可以看到:https://github.com/Treesaver/treesaver/blob/master/src/init.js这里的代码用到了Google开发的JS库:Closur......
  • Win7环境下TreeSaver编译环境的搭配
    首先你需要先搭配出”Win7环境下TreeSaver例子环境的搭配”然后才能继续下一步编译环境。例子环境搭配后,你可以在源代码目录下执行paver命令,搭配例子测试环境,也可以执行paverdebug生成带调试注释信息的treesaver脚本,当然也可以使用paverclean删除生成的文件。这些可以......
  • Huggingface Transformers库学习笔记(一):入门(Get started)
    前言Huggingface的Transformers库是一个很棒的项目,该库提供了用于自然语言理解(NLU)任务(如分析文本的情感)和自然语言生成(NLG)任务(如用新文本完成提示或用另一种语言翻译)的预先训练的模型。其收录了在100多种语言上超过32种预训练模型。这些先进的模型通过这个库可以非常轻松......
  • Getting Zero(Bfs)
    GettingZerotimelimitpertest2secondsmemorylimitpertest256megabytesinputstandardinputoutputstandardoutputSupposeyouhaveaninteger v.Inoneoperation,youcan:eitherset v=(v+1)mod32768orset v=(2⋅v)mod32768Youaregiv......
  • Get started with Docker 中文文档(2)——Part 2: Containers
    先决条件安装Docker1.13或更高版本。阅读第1部分的方向。让您的环境快速测试,以确保您全部设置:dockerrunhello-world介绍现在是开始构建Docker应用程序的时候了。我们将从这样一个应用程序的层次结构的底部开始,这是一个容器,我们在这个页面上介绍。在这个层次之上是一个服务,它......
  • 2305.19270Learning without Forgetting for Vision-Language Models
    https://arxiv.org/pdf/2305.19270.pdf2305.19270.pd  AbstractClass-IncrementalLearning(CIL)orcontinuallearningisadesiredcapabilityintherealworld,whichrequiresalearningsystemtoadapttonewtaskswithoutforgettingformerones.Whiletradi......
  • Could not commit Hibernate transaction,Transaction not successfully started
    CouldnotcommitHibernatetransaction,Transactionnotsuccessfullystarted1.数据库操作和业务分离。事务内属于业务验证抛出的异常问题或其他不符合当前业务规则的异常,挪到上一层级,如接口层或业务视图层,以此避免该类问题2.evict。获取当前session,evict当前数据库对象,避......
  • 打开.exe程序 弹出显示框 [ this application could not be started ]
    弹出点Yes! 点No!( 都是没用的~!都是没用的~!都是没用的~!)跳转下载下面的  。NETFramework( 都是没用的~!都是没用的~!都是没用的~!)尝试运行.NETFramework应用程序时,可能会收到“无法启动此应用程序”错误消息。如果此错误是由安装的.NETFramework版本未被检测到或.NE......
  • Getting Started / Basic Structures
    有序点云类似于图像,数据被分成行和列,其来源是立体相机或则TOF相机。其优点是最近邻操作的效率要高得多,从而加快了计算速度,降低了PCL中某些算法的成本。无序点云无序点云的width是点云的总数,height为1判断是无序点云还是有序点云的函数是isOrganized()......
  • C# System.lnvalidOperationException:"A second operation started on this context
    项目中使用了依赖注入,这个错误在我项目中的原因:在async修饰的异步方法中,调用执行数据库操作的方法时,没有使用await关键字调用,因为没有等待该调用,所以在调用完成之前将继续执行该方法。因此,已处理了注入的依赖项。......