随笔 - 27, 文章 - 0, 评论 - 29, 阅读 - 51238
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

jQuery为动态生成的select元素添加事件

Posted on   吕霖  阅读(14645)  评论(3编辑  收藏  举报
 
项目中需要在点击按钮时动态生成select元素,为防止每次点击按钮时从服务器端获取数据(因为数据都是相同的),可以这样写代码
1、首先定义全局js变量
var strVoucherGroupSelect ="";
2、在js中写好获取服务端数据的代码
function genVoucherGroupSelect(rowID){
    return $(strVoucherGroupSelect).attr("id", "sl_" + rowID).parent().html();    //返回增加ID后的下拉框完整html
}
function getVoucherGroupData(){
    $.ajax({
        type: "Post",
        url: "/BillWeb/OrgVoucher/GetVoucherGroup",
        dataType: "json",
        data: "",
        cache: true,
        success: function(res) {
                var str = $("<select></select>");
                var option = "";
                for(var j =0;j < res.length; j++)
                {
                    option += "<option value=\"" + res[j].Value + "\">" + res[j].Text + "</option>";
                }
                strVoucherGroupSelect = $(str).html(option).parent().html();
        }
    });
}
3 在页面中编写初始化代码
    $().ready(function(){
        getVoucherGroupData();
    });
4 需要动态增加select的时候,可以这样写
$("#divID").append(genVoucherGroupSelect(rowID) );

5 给select增加点击事件,在第四步后增加
$("#sl_0" + rowID).bind("onchange", function(){
      alert("你点击了下拉框");
})

编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示