Layui を使用して編集可能をサポートするアンケート調査システムを開発する方法
はじめに:
アンケートはデータを収集および分析するための重要なツールです。編集機能を備えたアンケート調査システムをいかに開発するかが重要な課題である。この記事では、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>
アンケート テンプレートの作成:
メイン コンテンツ領域で、アンケート テンプレートを作成できます。
<!-- 主体内容 --> <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>
// 定义一个全局变量,用来记录当前问题的索引 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++; });
// 保存问卷按钮的点击事件 $("#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("请求出错"); } }); });
<?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 サイトの他の関連記事を参照してください。