如果有人知道window.open()
在Meteor.call()
的回调中无法解决原因,我会很高兴。您可以通过在客户端上window.open(url)
的回调中调用Meteor.call('method',argument,callback(e,r){...})
来轻松地重现此问题。在回调之外它可以工作,并且在回调中,window.location = url
正确地重定向。
我的数据库中有一些来自filepicker.io的安全网址。由于提前生成所有策略和签名效率低下,我想在有人实际尝试检索这些文件时在click事件中生成它们。不幸的是,在Meteor.call('methodname',param,callback(e,r){...})
的客户回调中,window.open(url)
似乎不起作用,我无能为力。
模板
<template name="upload">
<div class="btn-group btn-group-vertical">
{{#each files}}
<button id="fp" class="btn btn-primary">{{filename}}</button>
{{/each}}
</div>
</template>
的客户机/ client.js
Template.upload.files=function(){
return files.find({});
}
Template.upload.events({
'click #fp':function(){
// window.open(this.url)
// if I uncomment the above line, a new window
// opens with the unsigned url
// (this.url is a valid mongo cursor)
Meteor.call('signedUrl',this.url,function(err,result){ // result is signed url
console.log(result); // loggs the correct url in the console
// window.location = result;
// if uncommented, the line above redirects correctly
window.open(result); // does NOT open the new window with the signed url
});
}
});
服务器/ server.js
Meteor.methods({
signedUrl: function(url) {
// some proven-to-work-code that you can find at
// http://stackoverflow.com/questions/18546676
console.log(signed_url); // loggs the correctly signed url on the server
return signed_url;
}
});
提前感谢您的任何提示!最好的问候
答案 0 :(得分:1)
这可能是由chrome / safari的反弹出过滤器捕获的。
您可能希望以非恶意方式使用新窗口,但现代浏览器需要用户输入才能打开新窗口。在回调中没有用户输入“触发器”,因此浏览器可能认为它是一个弹出/广告。
真的没有太多方法可以通过这个。您可以在运行回调时创建一个新按钮,然后让用户单击它以打开一个新窗口。