从动态表单发布到Chrome中的动态iframe会打开一个新窗口

时间:2015-09-09 16:07:18

标签: javascript forms google-chrome iframe dynamic

我正在做一些测试来创建一个允许跨域通信的JavaScript小部件。

我有一个脚本标记,可以放在任何会将动态表单和iframe注入其页面的网站上。

我的想法是将动态表单的target属性设置为动态iframe的名称,以便可以将数据从第三方站点发布到我的后端进行处理。

将它放在一起并在Firefox中运行良好,但在Chrome中,提交会强制打开一个新窗口。

如果我使用非动态iframe,它会突然发挥作用。但是,如果我希望我的小部件很容易让第三方集成到他们的网站中,那就不是很优雅了。

任何人都知道如何让这个工作?我不认为这是我的代码,因为正如我所说,当iframe是静态的时,代码可以工作。我已经验证了动态iframe的名称和ID是按预期设置的。

干杯。

我添加了一个演示此行为的JSFiddle。请注意,JavaScript实际上会放在HTML中div id Widget下面的脚本标记中。 https://jsfiddle.net/n67w5tm7/

(function($) {

    var TEST = (function() {

        var param = {
            source: '//localhost',
            gateway: '/gateway.php'
        },

        _target,

        _gateway,

        get = function(id) {
            var n = document.getElementById(id);
            return (typeof n === 'undefined' ? $() : $(n));
        },

        init = function() {

            _target = get('Widget');

                _gateway = $(document.body).append('iframe', {
                    src : param['source'] + param['gateway'],
                    name : 'Gateway',
                    id : 'Gateway'
                })
                .node();


                _submitter = _target.top()
                    .append('form', {
                        id: 'Form',
                        target: 'Gateway',
                        action: param['source'] + param['gateway'],
                        method: 'POST'
                    }).node();


                $(_submitter)
                    .append('fieldset', {
                        'class': 'three'
                    })  
                    .append('div', {
                        'class': 'row'
                    })
                    .append('label')
                        .addText('Some field')
                        .up()
                    .append('input', {
                        type: 'text',
                        name: 'field',
                        id: 'field'
                    })
                        .up()
                    .up()
                .append('input', {
                    type: 'submit',
                    value: 'Submit'
                        })
                        .up()
                    .up()
                .up();

                ready();
            },

            ready = function() {
                // Some work
            };

            function TEST() {
                init();
            };

            return TEST;
        })();

        return new TEST();

    })(ezJS);

1 个答案:

答案 0 :(得分:3)

我偶然发现了解决方案。

iframe name属性可能需要在添加到DOM之前设置。我用以下内容更新了我的JsFiddle(https://jsfiddle.net/n67w5tm7/1/):

append: function(tag, attrs) {
        var el = document.createElement(tag);
        if (tag === 'iframe' && attrs && attrs.name) {
            try {
                el.name = attrs.name; // This seems to fix it!
                el = document.createElement('<iframe name="' + attrs.name + '">');
            } catch (e) {}
        }

        _last(_ref).appendChild(el);
        _ref.push(el);
        if (attrs && typeof attrs === 'object') {
            _each(attrs, functions.attr);
        }
        return functions;
    },