0

0

如何在 AJAX 动态填充 后正确设置默认选中项

心靈之曲

心靈之曲

发布时间:2026-02-07 13:57:27

|

826人浏览过

|

来源于php中文网

原创

如何在 AJAX 动态填充 <select> 后正确设置默认选中项
后正确设置默认选中项 " />

本文详解为何在 ajax 异步加载下拉选项后 `$('#progress').val("xxx")` 失效,并提供三种可靠、兼容性良好的解决方案,包括原生 jsjquery 写法,确保选中逻辑在 dom 更新完成后准确执行。

在 Web 开发中,动态渲染

✅ 正确做法:选中逻辑必须置于 success 回调内部

以下三种方案均确保 DOM 更新与选中操作同步完成,推荐按场景选用:

传媒公司模板(RTCMS)1.0
传媒公司模板(RTCMS)1.0

传媒企业网站系统使用热腾CMS(RTCMS),根据网站板块定制的栏目,如果修改栏目,需要修改模板相应的标签。站点内容均可在后台网站基本设置中添加。全站可生成HTML,安装默认动态浏览。并可以独立设置SEO标题、关键字、描述信息。源码包中带有少量测试数据,安装时可选择演示安装或全新安装。如果全新安装,后台内容充实后,首页才能完全显示出来。(全新安装后可以删除演示数据用到的图片,目录在https://

下载

方案一:原生 JS —— 插入后直接赋值(最简洁)

$.ajax({
  url: 'data_control/orders/progress_select.php',
  type: 'POST', // 注意:type 和 method 不应同时使用,推荐统一用 type
  data: { selected_value: selected_value },
  dataType: 'JSON',
  success: function (response) {
    const select = document.getElementById('progress');
    select.innerHTML = ''; // 清空旧选项(可选,避免重复)

    response.forEach(item => {
      const option = document.createElement('option');
      option.value = item.progress_name;
      option.text = item.progress_name;
      select.appendChild(option);
    });

    // ✅ 关键:在此处设置选中值(DOM 已更新)
    select.value = 'Value to set'; // 原生写法,兼容所有浏览器
  }
});

方案二:原生 JS —— 创建时标记 selected 属性(语义清晰)

success: function (response) {
  const select = document.getElementById('progress');
  select.innerHTML = '';

  response.forEach(item => {
    const option = document.createElement('option');
    option.value = item.progress_name;
    option.textContent = item.progress_name;
    // ✅ 匹配目标值时直接设 selected=true
    if (item.progress_name === 'Value to set') {
      option.selected = true;
    }
    select.appendChild(option);
  });
}

方案三:一行式模板字符串(现代、高效)

success: function (response) {
  const target = 'Value to set';
  const html = response.map(item => 
    ``
  ).join('');

  document.getElementById('progress').innerHTML = html;
}

// 辅助函数:防止 XSS(重要!)
function escapeHtml(unsafe) {
  return unsafe
    .replace(/&/g, "&")
    .replace(//g, "youjiankuohaophpcn")
    .replace(/"/g, """)
    .replace(/'/g, "'");
}

⚠️ 注意事项与最佳实践

  • 避免混用 type 和 method:jQuery 中 type 已涵盖请求方法,method 字段多余,应删除以避免歧义;
  • 务必清空旧选项:若需替换内容,select.innerHTML = '' 或 select.length = 0 可防止重复添加;
  • 服务端返回 JSON 需严格校验:确保 response[i].progress_name 存在且为字符串,建议增加 if (item && typeof item.progress_name === 'string') 安全判断;
  • 优先使用 textContent 而非 text:option.text 在部分旧版 IE 中有兼容性问题,textContent 更标准;
  • XSS 防护不可少:动态插入用户数据(如数据库字段)前,必须 HTML 转义,否则存在安全风险。

✅ 总结

$('#progress').val(...) 失效的本质是时序错误,而非语法问题。只要将选中逻辑严格置于 success 回调内、DOM 操作完成后执行,即可 100% 解决。推荐方案一(select.value = ...)作为默认选择:简洁、高效、无依赖;若需更精细控制(如多选、禁用项),则采用方案二;追求代码密度与可读性平衡时,方案三配合转义函数是现代项目的优选。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

430

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

542

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

79

2025.09.10

jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

152

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

401

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

508

2023.12.04

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

39

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 11.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号