1

我将 blueimp-jquery-file-upload 与 smarty 一起使用,因为 blueimp 使用了脚本中带有 html 标签的奇怪脚本标签,它与 smarty 引擎冲突,结果我遇到了脚本故障。

<script id="template-upload" type="text/x-tmpl">

这是用于上传的脚本标签 截屏

但是当它渲染时,它的顺序不正确,我试图更改分隔符但它仍然不起作用

这是呈现的html

截屏

请任何人告诉我如何解决它,当我放置一些其他 JS 而不是 blueimp 上传脚本时,它可以正常工作。

即使这样也行不通

{literal}
<script id="template-upload" type="text/x-tmpl">
var a = 3;
<div  class="B">sdfsdfs</div>
 var j = 5;
<div class="A"></div>
</script>
{/literal}
4

1 回答 1

2

这个 BlueImp 插件使用另一个名为Templates 引擎的 jQuery 插件从 JavaScript 生成 HTML。他们碰巧使用与 Smarty 相同的语法,这似乎破坏了您的代码。然而,BlueImp 插件允许您通过手动将 HTML 定义为插件选项来覆盖此模板语言。你的 JavaScript 看起来像这样:

$('#fileupload').fileupload({
    filesContainer: $('#upload_files_container'),
    uploadTemplateId: null,
    downloadTemplateId: null,
    uploadTemplate: function (o) {
        var rows = $();
        $.each(o.files, function (index, file) {
            var row = $('<tr class="template-upload fade">' +
                '<td class="preview"><span class="fade"></span></td>' +
                '<td class="name"></td>' +
                '<td class="size"></td>' +
                (file.error ? '<td class="error" colspan="2"></td>' :
                        '<td><div class="progress">' +
                            '<div class="bar" style="width:0%;"></div></div></td>' +
                            '<td class="start"><button>Start</button></td>'
                ) + '<td class="cancel"><button>Cancel</button></td></tr>');
            row.find('.name').text(file.name);
            row.find('.size').text(o.formatFileSize(file.size));
            if (file.error) {
                row.find('.error').text(
                    locale.fileupload.errors[file.error] || file.error
                );
            }
            rows = rows.add(row);
        });
        return rows;
    },
    downloadTemplate: function (o) {
        var rows = $();
        $.each(o.files, function (index, file) {
            var row = $('<tr class="template-download fade">' +
                (file.error ? '<td></td><td class="name"></td>' +
                    '<td class="size"></td><td class="error" colspan="2"></td>' :
                        '<td class="preview"></td>' +
                            '<td class="name"><a></a></td>' +
                            '<td class="size"></td><td colspan="2"></td>'
                ) + '<td class="delete"><button>Delete</button> ' +
                    '<input type="checkbox" name="delete" value="1"></td></tr>');
            row.find('.size').text(o.formatFileSize(file.size));
            if (file.error) {
                row.find('.name').text(file.name);
                row.find('.error').text(
                    locale.fileupload.errors[file.error] || file.error
                );
            } else {
                row.find('.name a').text(file.name);
                if (file.thumbnail_url) {
                    row.find('.preview').append('<a><img></a>')
                        .find('img').prop('src', file.thumbnail_url);
                    row.find('a').prop('rel', 'gallery');
                }
                row.find('a').prop('href', file.url);
                row.find('.delete button')
                    .attr('data-type', file.delete_type)
                    .attr('data-url', file.delete_url);
            }
            rows = rows.add(row);
        });
        return rows;
    }
});

请参阅他们的文档。这将允许您在不使用 Smarty 语法的情况下生成 HTML。

于 2013-02-17T13:18:23.423 回答