wuruize888 2017-05-25 07:23 采纳率: 66.7%
浏览 939
已采纳

jQuery,后加元素问题,动作都不管用,怎么搞?

$(function () {

$("#newpren, #oldpren").click(function () {        //用这个创建的input元素,在minput函数里不管用怎么?其它的原始input元素都可以驱动那个minput函数。
        if ($(this).attr("id") === "newpren") {
            $("#newinput").empty();
            $("#newinput").append("<input id=\"newclass\" name=\"newclass\" style=\"margin-top:10px;\" mtype=\"str:4:30\" class=\"form-control\" placeholder=\"新父类名称\" min=\"5\" max=\"30\" type=\"text\"/><span></span>");
        } else if ($(this).attr("id") === "oldpren") {
            $("#newinput").empty();
            $("#newinput").append("<input id=\"oldclass\" name=\"oldclass\" style=\"margin-top:10px;\" mtype=\"str:4:30\" placeholder=\"旧子类列表\" class=\"form-control\" min=\"5\" max=\"30\" type=\"text\"/><span></span>");
        }
    });


         $('form :input').keyup(function () {
        MINPUT($(this));                
    });

        function MINPUT(typeS) {
        alert("生效!");
        }
  });                   
                    <div>
                    <button type="button" id="newpren">使用新父类</button>
                    <button type="button" id="oldpren">使用已有子类</button>
                </div>


  • 写回答

4条回答 默认 最新

  • Go 旅城通票 2017-05-25 08:02
    关注

    因为执行 $('form :input').keyup(function () {这个绑定的时候只绑定dom中已经存在的,你事件添加生成的再这个代码执行之后,没在dom树种所以没有绑定事件,重新绑定过就行了,如果你用的1.7+的jquery可以改为这样,用代理对动态生成的内容也有效

             $('form').on('keyup',':input',function () {
                MINPUT($(this));
            });
    

    1.6-的找到元素重新绑定一次事件

    
            $("#newpren, #oldpren").click(function () {        //用这个创建的input元素,在minput函数里不管用怎么?其它的原始input元素都可以驱动那个minput函数。
                if ($(this).attr("id") === "newpren") {
                    $("#newinput").empty();
                    $("#newinput").append("<input id=\"newclass\" name=\"newclass\" style=\"margin-top:10px;\" mtype=\"str:4:30\" class=\"form-control\" placeholder=\"新父类名称\" min=\"5\" max=\"30\" type=\"text\" /><span></span>")
                     .find('input').keyup(function () { MINPUT($(this)); });
                } else if ($(this).attr("id") === "oldpren") {
                    $("#newinput").empty();
                    $("#newinput").append("<input id=\"oldclass\" name=\"oldclass\" style=\"margin-top:10px;\" mtype=\"str:4:30\" placeholder=\"旧子类列表\" class=\"form-control\" min=\"5\" max=\"30\" type=\"text\" /><span></span>")
                    .find('input').keyup(function () { MINPUT($(this)); });
                }
            });
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)