Динамические данные scriptData в jQuery Uploadify - PullRequest
0 голосов
/ 20 февраля 2010

Я довольно новичок в javascript и jQuery. Я использую Uploadify для загрузки изображений на сервер. На странице есть несколько объектов Uploader. Мне нужно передать идентификатор объекта Uploader, который используется на сервере. Это то, что я до сих пор:

$('input.ImageUpload').uploadify({
    ...
    'scriptData': {'id': ??????},
    ...
});

Как я могу это сделать? Я пробовал "this.id" и "$ (this) .attr ('id')". Я даже правильно говорю об этом?

Ответы [ 2 ]

2 голосов
/ 21 февраля 2010

Я не уверен, что это идеально, но вот что я в итоге сделал:

$('input.ImageUpload').each(function() {
  $(this).uploadify({
    ...
    scriptData({'id': $(this).attr('id')},
    ...
  });
});
1 голос
/ 09 апреля 2010

Вот как я успешно его использую:

$(document).ready(function() {
    $(".upload").each(function() {
        $(this).uploadify({
            'uploader'      : '/code/js/jquery.uploadify/example/scripts/uploadify.swf',
            'script'        : '/code/js/jquery.uploadify/example/scripts/uploadify.php',
            'cancelImg'     : '/code/js/jquery.uploadify/example/cancel.png',
            'folder'        : '<?=$upload_path?>' + $(this).attr('id'),
            'queueID'       : 'fileQueue',
            'auto'          : true,
            'multi'         : false,
            'scriptData'        : ({'var_name': 'this_var_value'}),
            'fileDesc'          : 'Images and PDF files only! (JPG, PNG, PDF)',
            'fileExt'               : '*.pdf;*.jpg;*.jpeg;*.png',
            'buttonText'        : 'browse' +  $(this).attr('id')
        });
    });
});



<div id="fileQueue"></div>
<input class="upload" type="file" name="ImageUpload" id="_ID_1" /><br />
<input class="upload" type="file" name="ImageUpload" id="_ID_2" /><br />
<input class="upload" type="file" name="ImageUpload" id="_ID_3" /><br />
...