0

私はノックアウト.jsとノックアウト-sortable.jsを使用しています。ソート可能なテーブルを作成するため。このテーブルの列の 1 つは画像をアップロードする必要があり、テーブルを並べ替えることができます。アップロードは正常に機能しますが、テーブルを並べ替えると、細かいアップローダーのボタンが表示されず、すべての属性が失われます。

フィドル: http://jsfiddle.net/XdevK/6/

再現する手順:

  1. [アセットを追加] をクリックします
  2. もう一度 [アセットを追加] をクリックします。
  3. 2 番目のアセットを最初の位置に移動します。fineuploader ボタンがありません。

実際に起こっていることは、並べ替えが完了すると div コンテンツが削除されることです。

JS コード:

var CommunityAsset = function(value, description, name) {
        this.Value = value;  
        this.Description = ko.observable(description);
        this.Name = "fineUploader" + name;            
    }
    var viewOverview = function()
    {
        var self = this;

        self.communityAssets = ko.observableArray();

        self.clearAsset = function(data, event) {

               self.communityAssets.remove(data);   

        };

        self.Uploaders = {};
        self.addAsset = function() {
            var name = self.communityAssets().length;
            var asset = new CommunityAsset("http://placehold.it/240x160", "", name);                    
            self.communityAssets.push(asset);
            createFineUploader(name);
        };        
        self.addAssetWithParams = function(value, description, name) {            
            var asset = new CommunityAsset(value, description, name);        
            self.communityAssets.push(asset);
            createFineUploader(name);


        };        
    }
var vc = new viewOverview();
vc.addAssetWithParams("http://placehold.it/240x160", "Hola",0);

ko.applyBindings(vc, $("#communityOverview")[0]);    




 function createFineUploader(intIndex)
    {
        vc.Uploaders[intIndex] = new qq.FineUploader({
                            element: $('#fineUploader'+intIndex)[0],
                            request: {
                                endpoint: '/Communities/FileUpload'
                            },
                            autoUpload: true,
                            sizeLimit: 4000000, // max size
                            validation: {
                                allowedExtensions: ['jpeg', 'jpg', 'gif']
                            },                
                            text: {
                                uploadButton: '<i class="icon-upload icon-white"></i> Upload a file'
                            },
                            multiple: false,
                            template: '<div class="qq-uploader ">' +
                                    '<pre class="qq-upload-drop-area "><span>{dragZoneText}</span></pre>' +
                                    '<div class="qq-upload-button btn btn-success" style="width: auto;">{uploadButtonText}</div>' +
                                    '<ul class="qq-upload-list" style="margin-top: 10px; text-align: center;"></ul>' +
                                '</div>',
                            classes: {
                                success: 'alert alert-success',
                                fail: 'alert alert-error'
                            },
                            callbacks: {
                                onComplete: function(id, name, response) {      
                                    if (response.success) 
                                    {
                                        var asset = ko.utils.arrayFirst(vc.communityAssets(), function(currentAsset) {
                                            return currentAsset.Name == "fineUploader"+intIndex; // <-- is this the desired seat?
                                        });

                                        // asset found?
                                        if (asset) {
                                            asset.Value = response.path;                                            
                                        }                                     
                                    }
                                }
                            },
                            debug: true
                        });

    }

HTML

<div class="tab-pane" id="communityOverview"> 
<table class="table" >
                                <thead>
                                    <tr>
                                      <th>Sort Order</th>
                                      <th>Community Overview Image</th>
                                      <th>Community Overview Image Description</th>                  
                                    </tr>
                                </thead>
                                <tbody  data-bind="sortable: communityAssets">
                                    <tr>
                                        <td class="item"><span data-bind="text: $index" ></span>                     
                                        </td>
                                        <td class="item">                        
                                            <div class="image-options">
                                                <div class="control-group">                                                                                     
                                                    <div class="controls">
                                                        <img  style="width:240px; height:160px;"  data-bind="attr:{src: Value}" />                                                      
                                                    </div>
                                                    <br />                                                                                                        
                                                    <div data-bind="attr: {id:Name}"></div>
                                                </div>   
                                            </div><!-- .image-options -->
                                            <a href="Javascript:void(0);" data-bind="click: $root.clearAsset ">Delete Asset</a>
                                        </td>
                                        <td class="item">
                                            <textarea class="input-block-level" rows="11" cols="3" data-bind="value: Description"></textarea>                                            
                                        </td>                  
                                    </tr>              
                                </tbody>
                            </table>
    <a href="#" data-bind="click: addAsset">Add Task</a>                                
</div>

私が実際に起こっていると思うのは、ソータブルがテーブルを再作成するということです。これは、並べ替えのコールバックで Fineuploader ライブラリの再作成を実行する必要があることを意味します。

並べ替えが完了したら、ボタンをそのままにしておくにはどうすればよいですか?

4

1 に答える 1

0

fileUploader を再作成することにしました (これは、ソート可能なテーブルに挿入された他のプラグインで発生する可能性があります)。

ちょっと簡単でした。

これがコードです(シナリオを作成するのに時間がかかるため、jsfiddleではありません)。

HTML

<table class="table">
<thead>
<tr>
    <th>
        Sort Order
    </th>
    <th>
        Community Overview Image
    </th>
    <th>
        Community Overview Image Description
    </th>
</tr>
</thead>
<tbody data-bind="sortable: communityAssets">
<tr>
    <td class="item">
        <span data-bind="text: $index"></span>
    </td>
    <td class="item">
        <div class="image-options">
            <div class="control-group">
                <div class="controls">
                    <img style="width:240px; height:160px;" data-bind="attr:{src: URL}"/>
                </div>
                <br/>
                <div data-bind="attr: {id: 'fineUploader' + Name}">
                </div>
            </div>
        </div>
        <!-- .image-options -->
        <a href="Javascript:void(0);" data-bind="click: $root.clearAsset ">Delete Asset</a>
    </td>
    <td class="item">
        <textarea class="input-block-level" rows="11" cols="3" data-bind="value: Description"></textarea>
    </td>
</tr>
</tbody>
</table>

Javascript:

 var CommunityAsset = function(value, description, name, url) {
        this.URL = url;
        this.Value = value;  
        this.Description = ko.observable(description);
        this.Name = name;  
        this.FileName  = "";
        this.FileSize = "";          
    }
    var viewOverview = function()
    {
        var self = this;

        self.communityAssets = ko.observableArray();

        self.clearAsset = function(data, event) {

               self.communityAssets.remove(data);   

        };

        self.Uploaders = {};
        self.addAsset = function() {
            var name = self.communityAssets().length;
            var asset = new CommunityAsset("", "", name, "http://placehold.it/240x160");                    
            self.communityAssets.push(asset);
            createFineUploader(name);
        };


    self.addAssetWithParams = function(value, description, name, url) {            
        var asset = new CommunityAsset(value, description, name, url);        
        self.communityAssets.push(asset);

    };       
    self.recreateUploaders = function(arg) {   
        createFineUploader(arg.item.Name);
        if (arg.item.FileName != "")
        {
            $("#fineUploader"+arg.item.Name+" .qq-upload-list").append('<li class=" alert alert-success"><span class="qq-upload-file">'+arg.item.FileName+
            '</span><span class="qq-upload-size" style="display: inline;">'+arg.item.FileSize+'</span></li>');
        }            

function createFineUploader(intIndex)
{
    vc.Uploaders[intIndex] = new qq.FineUploader({
                        element: $('#fineUploader'+intIndex)[0],
                        request: {
                            endpoint: '/Communities/FileUpload'
                        },
                        autoUpload: true,
                        sizeLimit: 4000000, // max size
                        validation: {
                            allowedExtensions: ['jpeg', 'jpg', 'gif']
                        },                
                        text: {
                            uploadButton: '<i class="icon-upload icon-white"></i> Upload a file'
                        },
                        multiple: false,
                        template: '<div class="qq-uploader ">' +
                                '<pre class="qq-upload-drop-area "><span>{dragZoneText}</span></pre>' +
                                '<div class="qq-upload-button btn btn-success" style="width: auto;">{uploadButtonText}</div>' +
                                '<ul class="qq-upload-list" style="margin-top: 10px; text-align: center;"></ul>' +
                            '</div>',
                        classes: {
                            success: 'alert alert-success',
                            fail: 'alert alert-error'
                        },
                        callbacks: {
                            onComplete: function(id, name, response) {      
                                if (response.success) 
                                {
                                    var asset = ko.utils.arrayFirst(vc.communityAssets(), function(currentAsset) {
                                        return currentAsset.Name == intIndex; // <-- is this the desired seat?
                                    });

                                    if (asset) {
                                        var number = response.size;
                                        var size = "";
                                        if (number >= 1048576)
                                        {   
                                            number = number / 1048576;
                                            size = "MB";
                                        }
                                        else
                                        {
                                            number = number / 1024;
                                            size = "kB";

                                        }
                                        asset.FileSize = number.toFixed(1) + "" + size;
                                        asset.FileName = response.fileName;
                                        asset.Value = response.path;
                                    }                                     
                                }
                            }
                        },
                        debug: true
                    });

}              
     }; 
}
var vc = new viewOverview();  
ko.bindingHandlers.sortable.afterMove  = vc.recreateUploaders;
ko.applyBindings(vc, $("#communityOverview")[0]);

行が移動されko.bindingHandlers.sortable.afterMove = vc.recreateUploaders; た後、プラグインの作成を再作成します。FileName の一部を追加しました。これは、ファイルを正しくアップロードすると、行が移動するとファイル名のラベルも削除されるため、FileName ラベルが再び追加されるためです。

それが誰かを助けることを願っています!

于 2013-07-18T21:19:02.750 に答える