ホームページ >ウェブフロントエンド >jsチュートリアル >Layui を使用して編集可能なアンケート システムを開発する方法

Layui を使用して編集可能なアンケート システムを開発する方法

王林
王林オリジナル
2023-10-27 14:15:271256ブラウズ

Layui を使用して編集可能なアンケート システムを開発する方法

Layui を使用して編集可能をサポートするアンケート調査システムを開発する方法

はじめに:
アンケートはデータを収集および分析するための重要なツールです。編集機能を備えたアンケート調査システムをいかに開発するかが重要な課題である。この記事では、Layui フレームワークを使用して強力なアンケート システムを開発する方法を紹介し、具体的なコード例を示します。

  1. Layui のインストールと導入:
    まず、Layui フレームワークをインストールしてプロジェクトに導入する必要があります。 Layui は、CDN リンクを通じて、またはローカル ファイルをダウンロードして導入することによって導入できます。
  2. ページ レイアウト:
    次に、HTML ページを作成し、アンケート システムのレイアウトを定義する必要があります。 Layui のレイアウト コンポーネントを使用すると、これをすばやく実装できます。
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>问卷调查系统</title>
    <link rel="stylesheet" href="layui/css/layui.css">
</head>

<body>
    <div class="layui-layout layui-layout-admin">
        <div class="layui-header">
            <!-- 头部内容 -->
        </div>
        <div class="layui-side">
            <!-- 侧边栏内容 -->
        </div>
        <div class="layui-body">
            <!-- 主体内容 -->
        </div>
        <div class="layui-footer">
            <!-- 底部内容 -->
        </div>
    </div>
    <script src="layui/layui.js"></script>
    <script>
        layui.use('element', function(){
          var element = layui.element;

          //...这里可以写一些自定义的业务逻辑代码
        });
    </script>
</body>

</html>
  1. アンケート テンプレートの作成:
    メイン コンテンツ領域で、アンケート テンプレートを作成できます。

    <!-- 主体内容 -->
    <div class="layui-body">
     <div class="layui-container">
         <div class="layui-row">
             <div class="layui-col-md12">
                 <blockquote class="layui-elem-quote layui-quote-nm">
                     <button class="layui-btn layui-btn-primary" id="add-question">添加问题</button>
                     <button class="layui-btn" id="save">保存问卷</button>
                 </blockquote>
             </div>
             <div id="question-container" class="layui-col-md12">
                 <!-- 问题列表容器 -->
             </div>
         </div>
     </div>
    </div>
  2. 質問を動的に追加する:
    Layui のフォームコンポーネントとダイナミックバインディングイベント関数を利用することで、質問を動的に追加する機能を実現できます。
// 定义一个全局变量,用来记录当前问题的索引
var questionIndex = 0;

// 添加问题按钮的点击事件
$("#add-question").click(function() {
    // 动态创建一个问题节点
    var question = `
    <div class="layui-card">
        <div class="layui-card-header">问题${questionIndex+1}:</div>
        <div class="layui-card-body">
            <div class="layui-form-item">
                <div class="layui-input-block">
                    <input type="text" class="layui-input" name="question-${questionIndex}"/>
                </div>
            </div>
            <div class="layui-form-item">
                <div class="layui-input-block">
                    <button class="layui-btn layui-btn-xs" id="add-option-${questionIndex}">添加选项</button>
                </div>
            </div>
            <div id="option-container-${questionIndex}">
                <!-- 选项容器 -->
            </div>
        </div>
    </div>
    `;

    // 将问题节点添加到问题列表容器中
    $("#question-container").append(question);

    // 绑定添加选项按钮的点击事件
    $("#add-option-" + questionIndex).click(function() {
        // 获取当前问题节点下的选项容器
        var optionContainer = $("#option-container-" + questionIndex);

        // 动态创建一个选项节点
        var option = `
        <div class="layui-input-block">
            <input type="text" class="layui-input" name="option-${questionIndex}"/>
        </div>
        `;

        // 将选项节点添加到选项容器中
        optionContainer.append(option);
    });

    // 更新问题索引
    questionIndex++;
});
  1. アンケート データの保存:
    Layui の Ajax コンポーネントを通じて、アンケート データをバックエンド サーバーに保存できます。
// 保存问卷按钮的点击事件
$("#save").click(function() {
    var formData = layui.form.val("question-form"); // 获取表单数据

    // 发送Ajax请求,将表单数据保存到后台服务器
    layui.$.ajax({
        url: "save.php",
        type: "POST",
        data: formData,
        success: function(res) {
            if (res.code === 0) {
                layui.layer.msg("保存成功");
            } else {
                layui.layer.msg("保存失败");
            }
        },
        error: function() {
            layui.layer.msg("请求出错");
        }
    });
});
  1. バックエンド インターフェイス:
    最後に、アンケート データを保存するバックエンド インターフェイスを作成する必要があります。例として PHP を示します:
<?php
$questionIndex = 0;
$questions = $_POST;
$questionList = [];
while(isset($questions["question-".$questionIndex])){
    $question = $questions["question-".$questionIndex];

    $options = [];
    $optionIndex = 0;
    while(isset($questions["option-".$questionIndex."-".$optionIndex])){
        array_push($options, $questions["option-".$questionIndex."-".$optionIndex]);
        $optionIndex++;
    }

    $questionData = [
        "question" => $question,
        "options" => $options
    ];
    array_push($questionList, $questionData);
    $questionIndex++;
}

// 将问卷数据保存到数据库
// TODO: 保存逻辑

// 返回保存结果给前端
$result = [
    "code" => 0,
    "message" => "保存成功"
];
echo json_encode($result);
?>

要約:
上記の手順を通じて、Layui を使用して編集可能性をサポートするアンケート システムを開発し、具体的なコード例を提供することに成功しました。開発者は、実際の条件に基づいて詳細な調整と最適化を行い、独自のニーズを満たすことができます。この記事がお役に立てば幸いです!

以上がLayui を使用して編集可能なアンケート システムを開発する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。