【问题标题】:JavaScript Load Image from URL in a Crossrider browser extensionJavaScript 从 Crossrider 浏览器扩展中的 URL 加载图像
【发布时间】:2013-05-06 16:58:49
【问题描述】:

我目前正在使用 Crossrider 编写扩展程序,我需要使用 URL 直接加载图像以对其进行一些图像处理。但是,onload 事件似乎根本没有触发。

我做错了什么,或者甚至可以在浏览器扩展中做到这一点?

以下是相关代码:

var imga = document.createElement('img');
imga.src = obj.attr('href'); // URL of the image
imga.style.display = 'none';
imga.onload = function() {
        alert('Image loaded');
        var imgData = getImageData(imga, 0, imga.height - 3);
        alert('Got Image data');
};

编辑

这是完整的代码

function readImage(obj)
        {
            console.log('Reading');
            relayReadImage(obj.attr('href'));
        }

        function relayReadImage(link)
        {
            var dateObj = new Date();
            var newlink = link + "?t=" + dateObj.getTime();
            console.log(newlink);
            appAPI.request.get(
                {
                url: newlink,

                onSuccess: function(response, additionalInfo) {
                    console.log(response);
                },

                    onFailure: function(httpCode) {
                    alert('GET:: Request failed. HTTP Code: ' + httpCode);
                }

                });
        }

【问题讨论】:

  • 尝试在.onload 之后 设置.src 属性。它可能被缓存。另一种选择是将查询字符串添加到src,以便它破坏任何缓存。我更喜欢使用我的第一个建议
  • 刚刚试过,不行。

标签: javascript crossrider


【解决方案1】:

我是 Crossrider 的员工,很乐意为您提供帮助。如果我理解正确,您正在尝试使用页面 dom (obj.attr('href')) 中对象的 URL (href) 将图像加载到扩展程序中的变量中。您可以在 extension.js 文件中使用我们的跨浏览器 appAPI.request.get 方法来实现此目的,如下所示:

appAPI.ready(function($) {
    appAPI.request.get({
        url: obj.attr('href'),
        onSuccess: function(response) {
            var imgData = response;
            console.log(imgData);
        }
    });
});

但是,如果我误解了您的问题,请您澄清以下内容:

  1. obj 对象是什么?
  2. 您要实现什么目标,在什么情况下(在扩展程序中或在页面上)?

【讨论】:

  • 感谢您的回复。首先回答您的问题,obj 是用户拖动的图像对象,我们想对其进行一些图像处理,扩展程序将执行我们的命令。无论如何,经过一些测试,我们发现图像加载确实有效,但浏览器会从缓存中获取它。反正有这个吗?
  • 您可以简单地在 URL 中添加一个随机参数。如需更多信息,请参阅stackoverflow.com/questions/8749434/…
  • 似乎是解决方案,但是还有一个问题,我们不能将任何字符串连接到obj.attr('href')。浏览器似乎忽略了对其进行的任何操作,我无法使用alert() 记录或打印它。反正有这个吗?
  • 你能提供代码吗?您是否尝试过分配给变量然后连接变量?另外,您是否尝试过我提供的代码 ;-)
  • 编辑了问题并添加了代码。是的,我已经尝试将变量连接到另一个变量,以及您的代码。这只是一个非常不寻常的问题......
猜你喜欢
  • 2014-05-14
  • 2016-01-20
  • 2015-09-02
  • 1970-01-01
  • 2011-12-08
  • 2023-04-09
  • 2015-08-02
  • 1970-01-01
  • 2014-11-24
相关资源
最近更新 更多