ホームページ > ウェブフロントエンド > ライユイのチュートリアル > Lauiuiでデータバインディングを実装する方法

Lauiuiでデータバインディングを実装する方法

藏色散人
リリース: 2020-11-30 17:03:14
オリジナル
8354 人が閲覧しました

layui がデータ バインディングを実装する方法: まず、layui の css ファイルと js ファイルを導入し、次にレンダリング結果を表示するビューを作成し、次にテンプレートを記述し、script タグを使用してテンプレートを保存し、最後にテンプレートをレンダリングします。

Lauiuiでデータバインディングを実装する方法

このチュートリアルの動作環境: Windows 7 システム、layui バージョン 2.5.6。この記事はすべてのブランドのコンピューターに適用されます。

推奨: 「layUI チュートリアル

layui に基づく Laytpl はデータ バインディングを実装します

自分の庭のログインパスワードを思い出すのに長い時間がかかりました。ログインしてからどのくらい時間が経ったか想像してください。

テキスト
最初はlayuiを使っていくつかの管理システムを作成したので、本当に感じています管理バックエンドで最も一般的に使用されるクラスは、フォーム、テーブル、ポップアップ ウィンドウ クラスです。 lauiui が提供するフォームテーブルレイヤーはすでに非常にシンプルで使いやすく、基盤となるカプセル化に関係なく、使用方法が非常に簡素化されていると思います。 管理で使用されるフォーム テーブル レイヤーに加えて、統計データの表示や詳細ページなどのコンテンツの表示がよくあります。次に、テキスト統計データの表示など、統計データ (グラフを除く) を使用するものもありました。このとき、laytplベースのlayuiを使ってこの機能を表示すると実は優れています。

##最初に簡単なデータ バインディングを作成します

第一ステップ:layui の css ファイルと js ファイルを導入します (自分で導入) 第二ステップ:レンダリング結果を表示するビューを作成します。コードは次のとおりです。次のように:

 <p class="layui-row">        
 <p class="layui-col-md6" id="orderInfop"></p>       
</p>
ログイン後にコピー
ステップ 3: テンプレートを作成し、スクリプト タグを使用してテンプレートを保存します。コードは次のとおりです:

<script type="text/html" id="orderInfo">
        <div class="layui-card">
            <div class="layui-card-header">订单概况</div>
            <div class="layui-card-body">
                <ul class="layui-row layui-col-space10 layadmin-backlog">
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>营业额</h3>
                            <p><cite style="font-size:24px;">{{d.turnover}}</cite></p>
                        </a>
                    </li>
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>订单数</h3>
                            <p><cite style="font-size:24px;">{{d.orderNum}}</cite></p>
                        </a>
                    </li>
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>已发货</h3>
                            <p><cite style="font-size:24px;">{{d.delivered}}</cite></p>
                        </a>
                    </li>
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>未发货</h3>
                            <p><cite style="font-size:24px;">{{d.unDelivered}}</cite></p>
                        </a>
                    </li>
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>已取消</h3>
                            <p><cite style="font-size:24px;">{{d.cancelled}}</cite></p>
                        </a>
                    </li>
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>已收货</h3>
                            <p><cite style="font-size:24px;">{{d.received }}</cite></p>
                        </a>
                    </li>
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>已评价</h3>
                            <p><cite style="font-size:24px;">{{d.evaluated}}</cite></p>
                        </a>
                    </li>
                    <li class="layui-col-xs6 layui-col-sm3">
                        <a class="layadmin-backlog-body">
                            <h3>好评率</h3>
                            <p><cite style="font-size:24px;">{{d.favorableRate}}%</cite></p>
                        </a>
                    </li>
                </ul>
            </div>
        </div>
    </script>
ログイン後にコピー

ステップ 4: レンダリングテンプレートのコードは次のとおりです。


<script>
  layui.use([&#39;laytpl&#39;], function () {
      var laytpl = layui.laytpl;

      //订单统计(正常情况下,此处应是ajax返回后的数据,这里是模拟数据。)
      //渲染模板所用的数据
      var data = { turnover: "23,251", orderNum: "256", delivered: "16", unDelivered: "130", cancelled: "10", received: "100", evaluated: "80", favorableRate: "80" }

      var orderInfoTpl = orderInfo.innerHTML  //获取模板,即上面所定义的 <script id="orderInfo">
      , orderInfoDiv = document.getElementById(&#39;orderInfoDiv&#39;);  //视图 即上面的 <div id="orderInfoDiv">
      laytpl(orderInfoTpl).render(data, function (html) { //渲染视图
          orderInfoDiv.innerHTML = html;
      });
    })
 </script>
ログイン後にコピー

ステップ 5: 効果は次のように表示されます。

非常に簡単ではありませんか?多くのバックエンド システムはlayuiに基づいて開発されているため、一部のデータ表示タイプに遭遇し、従来のjqueryバインド方法を使用したくない場合は、これを使用するのが実際には非常に実用的です。

詳細データの表示

テーブルの場合は、クリックして詳細を表示します。この方法でデータを表示することもできます

ステップ 1 :インポートlayui(自分で導入したもの)のcssファイルとjsファイル、ページ内で使用しているcssスタイルは自分で書いたものです。

2 番目のステップ: テーブル データの表示。ここでは既知のデータを割り当てます。開発中に独自のデータに置き換えて、テーブルのクリック イベントを定義します。

 <table class="layui-hide" lay-filter="demoTableFilter" id="demoTable"></table>
ログイン後にコピー
  <script type="text/html" id="barDemo">      
   <a class="layui-btn layui-btn-xs" lay-event="detail">查看详情</a>
     </script>
ログイン後にコピー

レンダリングに使用されるデータ

<script type="text/html" id="demoDetail">
        <div>
            <div class="disF">
                <div class="flex1">
                    <div class="disF">
                        <label>姓名:</label>
                        <p class="flex1">{{d.username}}</p>
                    </div>
                </div>
                <div class="flex1">
                    <div class="disF">
                        <label>邮箱:</label>
                        <p class="flex1">{{d.email}}</p>
                    </div>
                </div>
                <div class="flex1">
                    <div class="disF">
                        <label>签名:</label>
                        <p class="flex1">{{d.sign}}</p>
                    </div>
                </div>
            </div>
            <div class="disF">
                <div class="flex1">
                    <div class="disF">
                        <label>性别:</label>
                        <p class="flex1">{{d.sex}}</p>
                    </div>
                </div>
                <div class="flex1">
                    <div class="disF">
                        <label>城市:</label>
                        <p class="flex1">{{d.city}}</p>
                    </div>
                </div>
                <div class="flex1">
                    <div class="disF">
                        <label>积分:</label>
                        <p class="flex1">{{d.experience}}</p>
                    </div>
                </div>
            </div>
        </div>
    </script>
ログイン後にコピー

以下はテーブルの割り当てです

table.render({
          elem: &#39;#demoTable&#39;
        , cols: [[ //标题栏
            { field: &#39;id&#39;, title: &#39;ID&#39;, width: 100 }
            , { field: &#39;username&#39;, title: &#39;用户名&#39;, width: 80 }
            , { field: &#39;email&#39;, title: &#39;邮箱&#39;, width: 180 }
            , { field: &#39;sign&#39;, title: &#39;签名&#39;, width: 180 }
            , { field: &#39;sex&#39;, title: &#39;性别&#39;, width: 80 }
            , { field: &#39;city&#39;, title: &#39;城市&#39;, width: 100 }
            , { field: &#39;experience&#39;, title: &#39;积分&#39;, minWidth: 80 }
            , {  width: 100, align: &#39;center&#39;, toolbar: &#39;#barDemo&#39; }
        ]]
        , data: [{
            "id": "10001"
            , "username": "杜甫"
            , "email": "xianxin@layui.com"
            , "sex": "男"
            , "city": "浙江杭州"
            , "sign": "人生恰似一场修行"
            , "experience": "116"
            , "ip": "192.168.0.8"
            , "logins": "108"
            , "joinTime": "2016-10-14"
        },{
            "id": "10002"
          , "username": "李白"
          , "email": "xianxin@layui.com"
          , "sex": "男"
          , "city": "浙江杭州"
          , "sign": "人生恰似一场修行"
          , "experience": "12"
          , "ip": "192.168.0.8"
          , "logins": "106"
          , "joinTime": "2016-10-14"
          , "LAY_CHECKED": true
         }]
      });
ログイン後にコピー

テーブルページ効果の表示

3番目のステップはポップアップを作成することです詳細データ ボックスをレンダリングするためのボックス

<p class="demoDetailp" style="display:none;padding:10px;">
        <p id="detailp"></p>
 </p>
ログイン後にコピー

4 番目のステップは、テーブルの [詳細の表示] をクリックして、laytpl を介してデータ バインディングを実装することです。コードは次のとおりです:

table.on(&#39;tool(demoTableFilter)&#39;, function (obj) {
          var data = obj.data;
          if (obj.event === &#39;detail&#39;) {
              index = layer.open({
                  title: &#39;查看详情&#39;,
                  type: 1,
                  move: false,
                  content: $(&#39;.demoDetailDiv&#39;),
                  area: [&#39;750px&#39;, &#39;300px&#39;],
                  resize: false,
                  scrollbar: false
              });
              var demoDetailTpl = demoDetail.innerHTML  //获取模板,
                , detailDiv = document.getElementById(&#39;detailDiv&#39;);  //视图
                laytpl(demoDetailTpl).render(obj.data, function (html) { //渲染视图
                    detailDiv.innerHTML = html;
              });
          }
      });
ログイン後にコピー

表示効果は次のとおりです。次のとおりです:

概要:

上記は、laytpl を使用してデータを記録する最も簡単な方法です。

以上がLauiuiでデータバインディングを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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