ホームページ > ウェブフロントエンド > jsチュートリアル > Node.js で Jade を始める方法の詳細な説明

Node.js で Jade を始める方法の詳細な説明

亚连
リリース: 2018-06-11 14:30:58
オリジナル
1340 人が閲覧しました

この記事では主に Node.js テンプレート エンジン Jade について詳しく紹介します。Jade は Node.js 用のテンプレート エンジンです。

Jade は Node.js のテンプレート エンジンであり、Haml の多くの側面を利用しているため、その構文は Haml に比較的似ています。さらに、Jade はスペースもサポートします。

1. タグ

Jade では、行頭のテキストはデフォルトで HTML タグとして解釈されます。また、開始タグを記述するだけで済みます。「<>」を追加する必要はありません。なぜなら、Jade が終了タグと開始タグをレンダリングしてくれるからです。例:

body 
  p 
    h1 Jade是Node.js的一个模板引擎
    p  它借鉴了Haml的很多地方,所以语法上和Haml比较相近。
  p 
    footer © Pandora
ログイン後にコピー

上記の Jade テンプレートによってレンダリングされる最終的な HTML コードは次のとおりです:

<body>
  <p>
    <h1> Jade是Node.js的一个模板引擎</h1>
    <p>它借鉴了Haml的很多地方,所以语法上和Haml比较相近。</p>
  </p>
  <p>
    <footer>© Pandora</footer>
  </p>
</body>
ログイン後にコピー

注: タグ名が記述されていない場合、デフォルトは p タグです。

2. 変数/データ

Jade テンプレートに渡されるデータはローカルと呼ばれます。 変数の値を出力するには、等号「=」を使用します。

(ローカル):

{
  title: "Express.js Guide",
  body: "The Comprehensive Book on Express.js"
}
ログイン後にコピー

Jade コード:

h1= title
p= body
ログイン後にコピー

レンダリングされた出力 HTML:

<h1>Express.js Guide</h1>
<p>The Comprehensive Book on Express.js</p>
ログイン後にコピー

3. 変数の読み取り

Jade の変数の読み取り値は #{name} を通じて実装されます。例:

- var title = "Node"

p I love #{title}
ログイン後にコピー

変数の値はテンプレートのコンパイル時に処理されるため、実行可能な JavaScript(-) では使用しないでください。

4. 属性

属性はラベルの後に「()」で囲まれ、複数の属性は「,」で区切られます。例: body (name1 = "value1"、name2 = "value2")。

p(id="content", class=&#39;main&#39;)
  a(href=&#39;http://csdn.net&#39;, title=&#39;csdn主页&#39;, target=&#39;_blank&#39;) CSDN:中国软件联盟
  form(action="/login")
    button(type="submit", value="提交")
ログイン後にコピー

出力:

<p id="content" class=&#39;main&#39;>
  <a href=&#39;http://csdn.net&#39; title=&#39;csdn主页&#39; target=&#39;_blank&#39;> CSDN:中国软件联盟</a>
  <form action="/login">
    <button type="submit" value="提交">
  </form>
</p>
ログイン後にコピー

動的属性:

動的属性は、属性の値が動的であること、つまり、属性の値を表すために変数が使用されることを意味します。記号「|」を使用すると、HTML ノードのコンテンツを新しい行に記述することができます。例:

a(href=url, data-active=isActive)
label
  input(type="checkbox", checked=isChecked)
  | yes / no
ログイン後にコピー

上記のテンプレートに提供されるデータ:

{
  url: "/logout",
  isActive: true,
  isChecked: false
}
ログイン後にコピー

レンダリング後の最終出力 HTML:

<a href="" data-active=" rel="external nofollow" data-active"></a>
<label>
  <input type="checkbox" />yes / no
</label>
ログイン後にコピー

注: 属性値が渡されない場合、属性値が false の属性は無視されます。

5. リテラル

手間を省くために、タグ名の直後にクラス名と ID 名を記述することができます。例:

p#content
  p.lead.center
    | Pandora_galen
    #side-bar.pull-right // 没有标签名,默认为“p”
    span.contact.span4
      a(href="/contact" rel="external nofollow" rel="external nofollow" ) contact me
ログイン後にコピー

レンダリングされた出力 HTML:

<p id="content">
  <p class="lead center">
  Pandora_galen
  <p id="side-bar" class="pull-right"></p>
  <span class="contact span4">
    <a href="/contact" rel="external nofollow" rel="external nofollow" > contact me </a>
  </span>
</p>
ログイン後にコピー

6. テキスト

元のテキストを出力するには、「|」記号を使用します。

p 
  | 我两年前开始学习前端
  | 在此之间,我学过了html, jQuery, JavaScript, Python, Css3, HTML5, Bootstrap, D3.js, SVG...而现在我在学Node。并且我已经深深的爱上了前端。
ログイン後にコピー

7. スクリプトブロックとスタイルブロック

HTML で

script.
  console.log("Hello world!");
  setTiemout(function() {
    window.location.href = "http://csdn.net"
  }, 1000);

  console.log("Good bye!");
ログイン後にコピー

コードを作成するには、

<script>
  console.log("Hello world!");
  setTiemout(function() {
    window.location.href = "http://csdn.net"
  }, 1000);

  console.log("Good bye!");
</script>
ログイン後にコピー

同様に、style.

8. JavaScript コード

-、= またはを使用します。 =これら 3 つのシンボルは、出力を操作できる実行可能な JS コードを Jade で記述するために使用されます。これは、HTML 要素を出力したり、JavaScript を挿入したりするときに便利です。ただし、これを行うときは、クロスサイト スクリプティング (XSS) 攻撃を避けるように注意する必要があります。

例えばこんなことができます! =配列を定義し、タグ データを出力します:

- var arr = [&#39;<a>&#39;, &#39;<b>&#39;, &#39;<c>&#39;]
ul
  -for (var i = 0; i < arr.length; i++)
    li
      span= i
      span!= "unescaped:" + arr[i] + "vs."
      span= "escaped:" + arr[i]
ログイン後にコピー

生成されたコードは次のとおりです:

<ul>
  <li><span>0</span><span>unescaped: <a>vs. </span><span>escaped: <a></span></li>
  <li><span>1</span><span>unescaped: <b>vs. </span><span>escaped: <b></span></li>
  <li><span>2</span><span>unescaped: <c>vs. </span><span>escaped: <c></span></li>
</ul>
ログイン後にコピー

テンプレート エンジン Jade と Handlebars の主な違いは次のとおりです。Jade ではほとんどすべての JavaScript をコード内に記述できますが、Handlebars では制限があります。開発 人間が使用できるのは、少数の組み込みヘルパーとカスタム ヘルパーのみです。

9. コメント

Jade のコメントには 2 つのタイプがあります:

<1>。ページに出力されないコメント - 「//」。 - "//- ”

// 普通注释,会输出到渲染后生成的HTML页面
p Hello Jade content

//- 特殊注释,不会输出到HTML页面
p (id="footer") copyright 2016
ログイン後にコピー

Output:

<!-- 普通注释,会输出到渲染后生成的HTML页面 -->
<p> Hello Jade content </p>

<p id="footer">copyright 2016</p>
ログイン後にコピー

10. If ステートメント

標準の JavaScript コードを記述できるように、接頭辞 - を if ステートメントに追加します。接頭辞や括弧を使用しないこともできます。もちろん後者の方がより簡潔です。

- var user = {}
- user.admin = Math.random() > 0.5

if user.admin
  button(class = "launch") Launch Spacecraft
else 
  button(class = "login") Log in
ログイン後にコピー

さらに、not があります。これは、どちらでもない、または に相当します。 。

注: コードの各行の末尾にはセミコロン「;」はありません

Jade の各ステートメント

は非常に単純で、各ステートメントを使用するだけです。

- var language = [&#39;JavaScript&#39;, &#39;Node&#39;, &#39;Python&#39;, &#39;Java&#39;]
p
  each value, index in language
    p= index + "," + value
ログイン後にコピー

出力:

<p>
  <p>0. JavaScript</p>
  <p>1. Node</p>
  <p>2. Python</p>
  <p>3. Java</p>
</p>
ログイン後にコピー

例 2:

- var language = [&#39;JavaScript&#39;: -1, &#39;Node&#39;: 2, &#39;Python&#39;: 3, &#39;Java&#39;: 1]

p 
  each value, key in languages
    p= key + ":" + value
ログイン後にコピー

出力:

<p>
  <p>JavaScript: -1</p>
  <p>Node: 2</p>
  <p>Python: 3</p>
  <p>Java: 1</p>
</p>
ログイン後にコピー

12. フィルター

フィルターの機能は次のとおりです: 別の言語でテキスト ブロックを書き込みます。 Markdown フィルターを使用するには、Marked および Markdown NPM パッケージに加えて、Markdown モジュールをインストールする必要があります。

13, case

p
  :markdown
    # practical Node.js
    [This book](http://csdn.net) really helps to grasp many coponents needed for modern-day web development.
ログイン後にコピー
14, Function mixin

Sass または compass mixin を使用したことがある場合は、間違いなくそれらに精通しているでしょう。Jade での mixin の使用法は基本的にそれらと同じです。

宣言構文: mixin name(param, param2, …….)

呼び出し: +name(data)

- var coins = Math.round(Math.random() * 10)

case coins
  when 0
    p You have no money
  when 1
    p You have a coin
  default
    p You have #{coins} coins!
ログイン後にコピー

出力:

mixin row(items)
  tr
    each item, index in items
      td= item

mixin table(tableData)
  table
    each row, index in tableData
      +row(row)

- var node = [{name: "express"}, {name: "Jade"}, {name: "Handlebars"}]
+table(node)

- var js = [{name: &#39;backbone&#39;}, {name: &#39;angular&#39;}, {name: "emberJS"}]
+table(js)
ログイン後にコピー

15. include

include は、JS および CSS 外部の導入と非常に似ています。ファイルの類似性。これはトップダウンのアプローチです。他のファイルを含むメイン ファイルで、何を使用するかを決定します。最初にメイン ファイルが処理され (データ ローカルはメイン ファイルで定義できます)、次にメイン ファイルに含まれるサブファイルが処理されます (サブファイルはメイン ファイルで定義されたデータ ローカルを使用できます)。 include Jade テンプレートの場合、 include /path/filename を使用します。

たとえば、ファイル A:

<table>
  <tr>
    <td>express</td>
  </tr>
  <tr>
    <td>Jade</td>
  </tr>
  <tr>
    <td>Handlebars</td>
  </tr>
</table>

<table>
  <tr>
    <td>backbone</td>
  </tr>
  <tr>
    <td>angular</td>
  </tr>
  <tr>
    <td>emberJS</td>
  </tr>
</table>
ログイン後にコピー

注: ここでテンプレート名とパスに二重引用符または一重引用符を追加する必要はありません。

別の例として、親ディレクトリから検索を開始します:

include ./includes/header
ログイン後にコピー

注: インクルード/パーシャルは実行時ではなくコンパイル時に処理されるため、ファイル名とファイル パスに変数を使用することはできません。

对于使用Sass、Compass又或者Less的人这些事再熟悉不过的了。

16、extend

extend与include“唱对台戏”,正好相反,extend是一种自底向上的方法。它所包含的文件决定它要替换主文件中哪那一部分。

使用格式: extend filename 和 block blockname;

示例-1: 在文件file_a里:

block header
  p some default text
block content
  p loading...
block footer
  p copyright
ログイン後にコピー

示例-2: 在文件file_b里:

extend file_a
block header
  p very specific text
block content
  .main-content
ログイン後にコピー

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在微信小程序中如何才能获取图片信息

在微信小程序中如何实现animation动画

使用百度地图如何去掉marker覆盖物具体该如何解决

在微信小程序中如何获取用户信息(详细教程)

在微信小程序中如何才可以获取用户手机号信息

在Vue中通过header组件如何开发(详细教程)

利用jquery如何写出PC端轮播图(详细教程)

详细讲解有关实现react服务器渲染问题

以上がNode.js で Jade を始める方法の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート