gpt4 book ai didi

jquery - 为什么我的 .on ('change' )不工作?

转载 作者:行者123 更新时间:2023-12-03 22:58:46 25 4
gpt4 key购买 nike

我正在将输入动态添加到我的页面中,因此需要使用 .on将事件附加到它们。

我正在尝试附加 change事件到type="file" input ,但它就是不起作用。

我尝试了两种方法,第一种:

$('.container').on('change', '.file-input-hidden' , function(){

其中输入的类别为 file-input-hidden .

第二个:

$('.container').on('change', 'input[type="file"]' , function(){

但当使用 input 选择/更改文件时,都不会触发该功能.

出了什么问题?

编辑:

在此查看页面:LINK

和js:

$('.container').on('click', '.file-browse' , function(){
var thisone = $(this).attr('id');
$('input[name="input-'+ thisone+'"]').click();
});

$('.file-input-hidden').on('change', function(){
var thetext = $(this).val();
var thetextsplit = thetext.split('\\').pop();
var thisone = $(this).attr('name').split('-').pop();
if($('.file-info').text() == thetextsplit){
alert('you have already selected this file');
$(this).replaceWith( $(this).val('').clone( true ) );
}
else{
$('#info-'+ thisone).text(thetextsplit);
$('#clear-'+ thisone).fadeIn(100);
var emptyinputs = $('.file-info:empty').length;
if(emptyinputs <1){
var filledinputs = $(".file-info:contains('.')").length;
var thisnumber = filledinputs + 1;
var filecontainer = $('<div>').addClass('file-container');
var fileinfo = $('<div>').addClass('file-info').attr('id','info-file'+thisnumber);
var filebrowse = $('<div>').addClass('file-browse').attr('id','file'+thisnumber).text('Browse');
var fileclear = $('<div>').addClass('file-clear').attr('id','clear-file'+thisnumber).text('X');
var newinput = $('<input>').attr({'type':'file','name':'input-file'+thisnumber}).addClass('file-input-hidden');
var thebody = $('.container');
(filecontainer).append(fileinfo,filebrowse,fileclear);
filecontainer.appendTo(thebody);

var theform = $('#hidden-inputs');
newinput.appendTo(theform);
}
}

if($(this).val() == ''){
$('#clear-'+thisone).fadeOut(100);
}
});

$('.container').on('click', '.file-clear' , function(){
var thisone = $(this).attr('id').split('-').pop();
$('input[name="input'+ thisone +'"]').replaceWith( $('input[name="input'+ thisone +'"]').val('').clone( true ) );
$('#info-'+ thisone).text('');
$(this).fadeOut(100);
});

HTML:

    <div class="container">
<div class="file-container">
<div class="file-info" id="info-file1"></div>
<div class="file-browse" id="file1">Browse</div>
<div class="file-clear" id="clear-file1">X</div>
</div>
</div>

<form action="" method="POST" enctype="multipart/form-data" id="hidden-inputs">
<input type="submit" style="clear:both; float:left;"/>
<input type='file' name="input-file1" class="file-input-hidden" />
</form>

最佳答案

您的代码...

jQuery:

$('.container').on('change', 'input[type="file"]' , function(){

HTML:

<div class="container">...</div>

<form>
<input type='file' name="input-file1" class="file-input-hidden" />
</form>

它不起作用,因为 input[type="file"] 不在 .container内部

将其放入 div.container 中或尝试类似的操作..

$(document).on('change', 'input[type="file"]' , function(){

See the documentation for .on() .

关于jquery - 为什么我的 .on ('change' )不工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14800285/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com