可以显示ajax传递的内容$(“form[name=‘f1‘]“).serialize();

这篇博客详细解析了如何使用jQuery的AjaxForm插件进行表单数据的POST提交,包括设置URL、数据类型、回调函数等关键步骤。通过`$(form[name='f1']).serialize()`方法,将表单数据序列化并传递到后台。成功提交后,调用`showAddUser`函数处理响应。

$("form[name='f1']").serialize();

可以显示ajax传递的内容

$("#save").click(function(){
        $("#f1").ajaxForm ({
            url:basePath+"/manager/addGoods.do",                    //发出请求的服务端url地址
            type:"post",                                    //post/get
            data:$("form[name='f1']").serialize(),    //服务端服务端传递参数
            dataType:"text",                                //服务端服务器返回的类型
            success:showAddUser                                    //执行成功后如何处理
        })
        $("#f1").submit();
    })

回车后

 

<%-- Created by IntelliJ IDEA. User: 13498 Date: 2025/9/22 Time: 14:25 To change this template use File | Settings | File Templates. $.post("jjb.do",function (f){ $.each(f,function (i,e){ $("#xx").append("<option value='"+e.cid+"'>"+e.name+"</option>"); }) },"json") --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Title</title> <script src="js/jquery.js"></script> <script type="text/javascript"> $(function () { // $("#zzz").click(function () { // var vn = $("zzz").val(); // if (vn =="" || vn == null) { // alert("错误"); // return; // } // }) // $("#zzz").click(function (){ // var vn = $("#jiji").val(); // if (vn =="" || vn == null) { // alert("错误"); // return; // } // $.post("b.do",$("form").serialize(),function (f){ // if (f>0){ // alert("添加成功") // }else { // alert("添加失败") // } // }) // }) // $.post("jjb.do", function (f) { // $.each(f, function (i, e) { // $("#xxt").append("<option value='" + e.cid + "'>" + e.name + "</option>"); // }) // }, "json") $.post("jjb.do", function (e) { var citys = ' '; $.each(e, function (i, f) { citys += '<option value="' + f.cid + '">' + f.cname + '</option>'; }); // $("#abc").click(function (){ // $.post("c.do",$("button").serialize(),function (f){ // if (f>0){ // alert(yes) // }else { // alert(no) // } // }) // }) // $("#zzz").click(function (){ // const = $(this).val(); // $.post("m.do",$("form").serialize(),function (f){ // if (f>0){ // alert(yes) // }else { // alert(no) // } // }) // }) var f1 = '<div class="station-group">' + '<p> <select name="kk">' + citys + '</select>' + '<input type="hidden" name="kprice" id="xxt" value=" ">' + ' 0</p>' + '</div>'; $(".sc").before(f1); $(".abc1").click(function(e) { e.preventDefault(); var station = '<div class="station-group">' + '<p> <select name="kstation">' + citys + '</select>' + ' <input type="text" name="kprice">' + '</div>'; $(".sc").before(station); }); },"json"); $(".abc1").on("click", function (f1) { }); <%--$("#jiji").click(function (){--%> <%-- var qwe=${this}.val();--%> <%--})--%> $("#zzz").click(function () { $.post("m.do", function (f) { if (f == 2) { alert("添加成功") } else { alert("添加失败") } }); }); <%--//const selectedValue = $(this).val();--%> <%-- let counter = 1; // 元素计数器--%> <%-- // 添加输入框功能--%> <%-- function addInput() {--%> <%-- const container = document.getElementById("imsb");--%> <%-- // 创建下拉框容器--%> <%-- const dropdownContainer = document.createElement("div");--%> <%-- dropdownContainer.className = "dropdown-container";--%> <%-- dropdownContainer.id = `dropdown-${counter}`;--%> <%-- // 临时显示加载状态--%> <%-- dropdownContainer.innerHTML = `<select disabled>--%> <%-- <option>加载选项中...</option>--%> <%-- </select>`;--%> <%-- container.appendChild(dropdownContainer);--%> <%-- // AJAX 请求获取选项数据--%> <%-- fetch('jjb.do') // 替换为实际API端点--%> <%-- .then(response => response.json())--%> <%-- .then(options => {--%> <%-- // 创建下拉框元素--%> <%-- const select = document.createElement("select");--%> <%-- select.name = `dropdownField`+`${counter}`;/*${counter}*/--%> <%-- select.id = `ccc`+`${counter}`;/*${counter}*/--%> <%-- // 添加默认选项--%> <%-- const defaultOption = document.createElement("option");--%> <%-- defaultOption.value = " ";--%> <%-- defaultOption.textContent = "-- 请选择 --";--%> <%-- select.appendChild(defaultOption);--%> <%-- // 填充动态选项--%> <%-- options.forEach(option => {--%> <%-- const optionElement = document.createElement("option");--%> <%-- optionElement.value = option.cid;--%> <%-- optionElement.textContent = option.cname;--%> <%-- select.appendChild(optionElement);--%> <%-- });--%> <%-- // 替换加载状态--%> <%-- dropdownContainer.innerHTML = '';--%> <%-- dropdownContainer.appendChild(select);--%> <%-- })--%> <%-- .catch(error => {--%> <%-- console.error('加载选项失败:', error);--%> <%-- dropdownContainer.innerHTML = `<select class="error-state">--%> <%-- <option>加载失败,请重试</option>--%> <%-- </select>`;--%> <%-- });--%> <%-- const newInput = document.createElement("div");--%> <%-- newInput.className = "input-container";--%> <%-- newInput.innerHTML = `--%> <%-- <input type="text" placeholder="输入框 ${counter}" name="inputField${counter}">--%> <%-- `;--%> <%-- container.appendChild(newInput);--%> <%-- // 新增:添加下拉框功能--%> <%-- const container = document.getElementById("inputsContainer");--%> <%-- const newDropdown = document.createElement("div");--%> <%-- newDropdown.className = "dropdown-container";--%> <%-- // 创建带选项的下拉框--%> <%-- newDropdown.innerHTML = `--%> <%-- <select name="dropdownField${counter}">--%> <%-- <option value=" ">-- 请选择 --</option>--%> <%-- </select>--%> <%--`;--%> <%-- container.appendChild(newDropdown);--%> <%-- counter++;--%> <%-- } // counter++; // } // // 新增:动态加载下拉选项(可选功能) // function loadDropdownOptions(selectElement, options) { // options.forEach(option => { // const optionElement = document.createElement("option"); // optionElement.value = option.value; // optionElement.textContent = option.label; // selectElement.appendChild(optionElement); // }); // }optionElement--%> </script> </head> <body> <form id="imsb"> 车次名称: <input type="text" name="jiji" id="jiji" value=""> <button id="cid" class="abc1" name="abc">增加途径站</button> <button id="zzz" type="button">新增</button> <div class="sc"> </div> </form> <%--<button id="zz" name="zz">添加途径站</button>--%> <%--<select id="xx" name="xx">--%> <%-- <option>--请选择--</option>--%> <%--</select>--%> <!-- 输入框容器 --> <%--<div id="inputsContainer">--%> <%-- <div class="input-container">--%> <%-- <input type="text" placeholder=" ">--%> <%-- </div>--%> <%--</div>--%> <!-- 添加按钮 --> <%--<button onclick="addInput()" id="zz" name="zz">添加途径站</button>--%> </body> </html> 点击添加为什么没有反应,不要做任何状实代码,只要简单实现即可
09-24
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>积分商城网厅常见问题分类配置</title> <script src="../js/jquery-1.min.js"></script> <script src="../js/bootstrap.min.js"></script> <link href="../css/bootstrap.min.css" rel="stylesheet"> <script src="../js/lay.js"></script> <!-- 添加 TinyMCE 引用 --> <script src="../js/tinymce/tinymce.min.js"></script> <style> /* 添加编辑器样式调整 */ .tox-tinymce { border-radius: 4px !important; border: 1px solid #dcdfe6 !important; } /* 隐藏原始文本区域 */ #content { display: none; } </style> </head> <style> body { font-family: "Microsoft YaHei", Arial, sans-serif; max-width: 1400px; margin: 30px auto; padding: 20px; background-color: #f8f9fa; } .hidden-id { display: none; } .form-container { background-color: white; padding: 40px; border-radius: 10px; box-shadow: 0 2px 12px rgba(0,0,0,0.08); } .form-section { border: 1px solid #ebeef5; padding: 20px; margin-bottom: 25px; border-radius: 8px; background: #fafafa; } .form-section h3 { color: #409eff; margin: 0 0 20px 0; padding-bottom: 10px; border-bottom: 1px solid #ebeef5; font-size: 16px; } .table { width: 100%; border-collapse: collapse; margin-bottom: 20px; } .table th, .table td { padding: 12px 15px; border: 1px solid #ddd; text-align: left; } .table th { background-color: #f5f5f5; font-weight: 600; } .table tr:nth-child(even) { background-color: #f9f9f9; } .table tr:hover { background-color: #f1f1f1; } .btn { padding: 6px 12px; border-radius: 4px; cursor: pointer; font-size: 14px; border: none; transition: all 0.3s; display: inline-flex; align-items: center; justify-content: center; } .btn-primary { background-color: #409eff; color: white; } .btn-primary:hover { background-color: #66b1ff; } .btn-success { background-color: #67c23a; color: white; } .btn-success:hover { background-color: #85ce61; } .btn-danger { background-color: #f56c6c; color: white; } .btn-danger:hover { background-color: #f78989; } .btn-sm { padding: 4px 8px; font-size: 12px; } .modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0,0,0,0.4); } .modal-content { background-color: #fefefe; margin: 10% auto; padding: 20px; border: 1px solid #888; width: 50%; border-radius: 8px; } .close { color: #aaa; float: right; font-size: 28px; font-weight: bold; cursor: pointer; } .close:hover { color: black; } .form-group { margin-bottom: 15px; } .form-group label { display: block; margin-bottom: 5px; font-weight: 600; color: #606266; } .form-control { width: 100%; padding: 8px 12px; border: 1px solid #dcdfe6; border-radius: 4px; box-sizing: border-box; } textarea.form-control { height: auto; min-height: 100px; } .required label::before { content: "*"; color: #f56c6c; margin-right: 4px; } .child-node { padding-left: 30px; background-color: #f9f9f9; vertical-align: middle; } .submit-btn { display: block; width: 200px; margin: 20px auto 0; padding: 10px; background: #409eff; color: white; border: none; border-radius: 4px; cursor: pointer; font-size: 14px; transition: all 0.3s; } .submit-btn:hover { background: #66b1ff; } .action-buttons { text-align: left; /* 内容左对齐 */ } .action-buttons button { display: inline-block; margin-right: 5px; /* 按钮之间的间距 */ vertical-align: middle; /* 垂直居中 */ } .table th:nth-child(4), .table td:nth-child(4) { width: 15%; /* 与表头设置一致 */ min-width: 180px; /* 设置最小宽度防止内容挤压 */ white-space: nowrap; /* 防止内容换行 */ } </style> <body> <div class="form-container"> <div class="form-section"> <div style="display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px;"> <h3 style="margin: 0 auto;">常见问题分类配置</h3> <button id="addTopCategory" class="btn btn-primary">添加一级分类</button> </div> <table class="table" id="categoryTable"> <thead> <tr> <th width="15%">分类名称</th> <th width="50%">分类内容</th> <th width="5%">排序</th> <th width="30%">操作</th> </tr> </thead> <tbody id="categoryList"> <!-- 动态加载数据 --> </tbody> </table> </div> </div> <!-- 添加/编辑分类的模态框 --> <div id="categoryModal" class="modal"> <div class="modal-content"> <span class="close">×</span> <h3 id="modalTitle">添加分类</h3> <form id="categoryForm" novalidate> <input type="hidden" id="id" name="id"> <input type="hidden" id="pid" name="pid" value="0"> <div class="form-group required"> <label for="name">分类名称:</label> <input type="text" class="form-control" id="name" name="name" placeholder="请输入分类名称,同级别不允许重复" required> </div> <div class="form-group required" id="contentGroup"> <label for="content">分类内容:</label> <textarea class="form-control" id="content" name="content" placeholder="请输入分类描述" required></textarea> </div> <div class="form-group required"> <label for="orderNum">排序顺序: <span style="color: #888; font-size: 12px; margin-left: 5px;">值越小越靠前,请输入正整数</span> </label> <input type="number" class="form-control" id="orderNum" name="orderNum" placeholder="请输入分类排序,同级别不允许重复" required min="1" step="1"> </div> <button type="submit" class="submit-btn">保存</button> </form> </div> </div> <script> // 动态设置 required 的函数 function setContentRequired(required) { if (required) { $('#content').attr('required', 'required'); $("#contentGroup").removeClass("hidden"); tinymce.get('content').show(); $('#content').css({visibility: 'visible', position: 'static'}); // 移除隐藏样式 } else { $('#content').removeAttr('required'); $("#contentGroup").addClass("hidden"); tinymce.get('content').hide(); $('#content').css({visibility: 'hidden', position: 'absolute', left: '-9999px'}); // 恢复隐藏样式 } } $(document).ready(function() { // 初始化 TinyMCE tinymce.init({ license_key: 'gpl', selector: '#content', language: 'zh_CN', language_url: '../js/tinymce/langs/zh_CN.js', height: 300, plugins: 'link lists image table code help wordcount', toolbar: 'undo redo | formatselect | bold italic | alignleft aligncenter alignright | bullist numlist outdent indent | link image | code help', skin: 'oxide', content_css: 'default', menubar: false, branding: false, relative_urls: false, remove_script_host: false, // 自定义图片上传处理 images_upload_handler: function(blobInfo, progress) { return new Promise((resolve, reject) => { // 创建FormData对象 const formData = new FormData(); formData.append('file', blobInfo.blob(), blobInfo.filename()); // 显示上传进度 progress(0); if (blobInfo.blob().size > 2 * 1024 * 1024) { // 2MB限制 $.MsgBox.Alert("温馨提示","文件大小不能超过2MB"); return; } const allowedTypes = ['image/jpeg', 'image/png', 'image/gif']; if (!allowedTypes.includes(blobInfo.blob().type)) { $.MsgBox.Alert("温馨提示","只支持JPEG、PNG、GIF格式的图片"); return; } // 使用jQuery AJAX进行上传 $.ajax({ url: '../point/uploadFileNew?limit=010', type: 'POST', data: formData, contentType: false, processData: false, xhr: function() { const xhr = new XMLHttpRequest(); xhr.upload.addEventListener('progress', function(e) { if (e.lengthComputable) { progress((e.loaded / e.total) * 100); } }); return xhr; }, success: function(response) { if (response.state === '200') { progress(100); resolve(response.filePath); // 返回图片URL } else { $.MsgBox.Alert("温馨提示", response.msg || "未知错误"); } }, error: function(xhr) { $.MsgBox.Alert("温馨提示", "网络错误:" + xhr.statusText); } }); }); }, setup: function(editor) { editor.on('init', function() { console.log('TinyMCE 初始化成功'); }); editor.on('error', function(e) { console.error('TinyMCE 错误:', e); }); editor.on('change', function() { // 内容变化时的逻辑(如实时保存) }); }, valid_elements: 'p,br,strong/b,em/i,u,ol,ul,li,h1,h2,h3,h4,a[href|target=_blank],img[src|alt|title|width|height|class]', valid_children: '-p[strong/b|em/i|u|a|img],-li[p|ol|ul]', extended_valid_elements: '', invalid_elements: 'script,iframe,object,embed,form,input,textarea,button,select,option,style', content_security_policy: "default-src 'self'; img-src 'self' data:; media-src 'none'; script-src 'none';", forced_root_block: 'p', force_br_newlines: false, convert_newlines_to_brs: false, remove_linebreaks: false, // 允许的CSS类 valid_classes: { '*': 'text-left,text-center,text-right,text-justify' }, // 粘贴过滤设置 paste_as_text: false, paste_postprocess: function(editor, node) { // 额外的粘贴后处理 } }); // 加载分类数据 loadCategoryData(); // 打开添加一级分类模态框 $("#addTopCategory").click(function() { $("#modalTitle").text("添加一级分类"); $("#categoryForm")[0].reset(); $("#id").val(""); $("#pid").val("0"); $("#content").removeAttr("required"); $("#contentGroup").addClass("hidden"); tinymce.get('content').hide(); $("#categoryModal").show(); setContentRequired(false); }); // 添加 orderNum 输入限制 $("#orderNum").on('input', function() { let value = parseInt($(this).val()) || 0; if (value < 1) { $(this).val(1); } }); // 关闭模态框 $(".close").click(function() { $("#categoryModal").hide(); tinymce.get('content').setContent(''); }); // 点击模态框外部关闭 $(window).click(function(event) { if (event.target == $("#categoryModal")[0]) { $("#categoryModal").hide(); tinymce.get('content').setContent(''); } }); // 提交表单 $("#categoryForm").submit(function(e) { e.preventDefault(); // 验证分类名称不能为空 var name = $("#name").val().trim(); if (name === '') { $.MsgBox.Alert("提示", "分类名称不能为空"); $("#name").focus(); // 聚焦到输入框 return; } // 验证分类内容(如果是必填的) if ($("#content").is(':required') && tinymce.get('content').getContent().trim() === '') { $.MsgBox.Alert("提示", "分类内容不能为空"); tinymce.get('content').focus(); // 聚焦到编辑器 return; } // 同步编辑器内容到 textarea var content = tinymce.get('content').getContent(); $('#content').val(content); saveCategory(); }); }); // 加载分类数据 function loadCategoryData() { $.ajax({ url: "../problemClassification/list", type: "GET", dataType: "json", success: function(data) { renderCategoryTable(data); }, error: function() { $.MsgBox.Alert("提示", "加载分类数据失败"); } }); } // 渲染分类表格 function renderCategoryTable(data) { var html = ""; $.each(data, function(index, item) { html += '<tr data-id="' + item.id + '">'; html += ' <td class="hidden-id">' + item.id + '</td>'; // 隐藏的ID列 html += ' <td>' + item.name + '</td>'; html += ' <td>' + (item.content || '') + '</td>'; // 新增内容html += ' <td>' + (item.orderNum || 0) + '</td>'; html += ' <td class="action-buttons">'; html += ' <button class="btn btn-primary btn-sm edit-btn" data-id="' + item.id + '">编辑</button>'; html += ' <button class="btn btn-success btn-sm add-child-btn" data-id="' + item.id + '">添加子类</button>'; html += ' <button class="btn btn-danger btn-sm delete-btn" data-id="' + item.id + '">删除</button>'; html += ' </td>'; html += '</tr>'; // 添加子分类 if (item.chilsNode && item.chilsNode.length > 0) { $.each(item.chilsNode, function(i, child) { html += '<tr class="child-node" data-id="' + child.id + '">'; html += ' <td class="hidden-id">' + child.id + '</td>'; // 隐藏的ID列 html += ' <td>└ ' + child.name + '</td>'; html += ' <td>' + (child.content || '') + '</td>'; // 新增内容html += ' <td>' + (child.orderNum || 0) + '</td>'; html += ' <td class="action-buttons">'; html += ' <button class="btn btn-primary btn-sm edit-btn" data-id="' + child.id + '">编辑</button>'; html += ' <button class="btn btn-danger btn-sm delete-btn" data-id="' + child.id + '">删除</button>'; html += ' </td>'; html += '</tr>'; }); } }); $("#categoryList").html(html); // 绑定按钮事件 $(".edit-btn").click(function() { var id = $(this).data("id"); editCategory(id); }); // 添加子分类按钮点击事件 $(".add-child-btn").click(function() { var pid = $(this).data("id"); $("#modalTitle").text("添加子分类"); $("#categoryForm")[0].reset(); $("#id").val(""); $("#pid").val(pid); $("#content").attr("required", true); $("#contentGroup").removeClass("hidden"); tinymce.get('content').show(); // 显示编辑器 $("#categoryModal").show(); setContentRequired(true); }); $(".delete-btn").click(function() { var id = $(this).data("id"); $.MsgBox.Confirm("提示", "确定要删除这个分类吗?", function() { deleteCategory(id); }); }); } // 编辑分类 function editCategory(id) { $("#modalTitle").html("编辑分类 <small>(加载中...)</small>"); // 先确保编辑器实例存在 if (!tinymce.get('content')) { console.error('TinyMCE 编辑器未初始化'); $.MsgBox.Alert("温馨提示", "编辑器初始化失败,请刷新页面重试"); return; } $.ajax({ url: "../problemClassification/get/" + id, type: "GET", dataType: "json", success: function(data) { $("#modalTitle").text("编辑分类"); $("#id").val(data.id); $("#name").val(data.name); $("#orderNum").val(data.orderNum); $("#pid").val(data.pid); // 确保编辑器可见性正确 if(data.pid == 0) { setContentRequired(false); } else { setContentRequired(true); } // 延迟设置内容以确保编辑器就绪 setTimeout(function() { try { tinymce.get('content').setContent(data.content || ''); $("#categoryModal").show(); } catch(e) { console.error('设置编辑器内容失败:', e); $.MsgBox.Alert("温馨提示", "编辑器内容设置失败,请重试"); } }, 100); }, error: function() { $.MsgBox.Alert("温馨提示", "获取分类信息失败"); } }); } // 保存分类 function saveCategory() { // 获取提交按钮,并禁用 + 修改文字 var $submitBtn = $("#categoryForm").find("button[type='submit']"); $submitBtn.prop("disabled", true).text("保存中..."); // 强制同步 TinyMCE 内容到 textarea tinymce.get('content').save(); // 自定义验证 if ($("#content").is(':required') && tinymce.get('content').getContent().trim() === '') { $.MsgBox.Alert("温馨提示", '分类内容不能为空'); $submitBtn.prop("disabled", false).text("保存"); // 恢复按钮状态 return false; } // 新增 orderNum 校验 const orderNum = parseInt($("#orderNum").val()); if (isNaN(orderNum) || orderNum < 1) { $.MsgBox.Alert("温馨提示", "排序顺序必须为正整数"); $submitBtn.prop("disabled", false).text("保存"); // 恢复按钮状态 return false; } var formData = $("#categoryForm").serialize(); var url = $("#id").val() ? "../problemClassification/update" : "../problemClassification/add"; $.ajax({ url: url, type: "POST", data: formData, success: function(response) { if (response === "添加成功" || response === "更新成功") { $("#categoryModal").hide(); loadCategoryData(); } else { $.MsgBox.Alert("温馨提示", response); } }, error: function() { $.MsgBox.Alert("温馨提示", "操作失败"); }, complete: function() { // 无论成功或失败,最终恢复按钮状态 $submitBtn.prop("disabled", false).text("保存"); } }); } // 删除分类 function deleteCategory(id) { $.ajax({ url: "../problemClassification/delete/" + id, type: "POST", success: function(response) { if(response === "删除成功") { loadCategoryData(); } else { $.MsgBox.Alert("温馨提示", response); } }, error: function() { $.MsgBox.Alert("温馨提示", "删除失败"); } }); } </script> </body> </html> 分析一下,图片上传之后会替换content中的img url以及编辑的时候回显和列表页回显吗
06-19
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值