Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >HTML背景: W3C学校说它有效,在真实生活中不起作用

HTML背景: W3C学校说它有效,在真实生活中不起作用
EN

Stack Overflow用户
提问于 2014-11-18 00:08:03
回答 1查看 380关注 0票数 0

我正在努力学习如何在HTML中使用画布对象,而且我一直在使用W3学校上的资源,发现它们非常有用。

我试图创建一个图像对象和一个画布对象,然后在画布上绘制图像作为背景,然后在背景图像上画线或多边形。我已经在“W3学校”页面上成功地做到了这一点,但是当我将该文件复制并粘贴到本地文本编辑器中时,然后将其保存到我的iMac上,并尝试将其加载到Chrome或Safari中,图像可以自己看到,但不能作为画布的背景。因此,它可以很好地工作在他们的“自己试试看!”编辑器 (在Chrome内),但不适用于相同的源在我的计算机上的html文件。

(而且,我下载了"img_the_scream.jpg“文件,并将其保存在我的目录中,它将作为图像本身加载。当我完成这项工作时,我计划使用两个画布,每个画布都有自己的背景图像和自己的多边形和线条,所以我在变量的末尾有一个'1‘,当我这样做时。)

以下是HTML代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html>
<body>
 <p>Image to use:</p>
 <!-- <div style="display:none;"> -->
  <img id="pic1" src="img_the_scream.jpg" alt="The Scream" width="220" height="277">
  <br>
 <!-- </div> -->
 <p>Canvas:</p>
 <canvas id="can1" width="250" height="300" style="border:1px solid #d3d3d3;">
 Your browser does not support the HTML5 canvas tag.</canvas>
 <script>
  var c1 = document.getElementById("can1");
  var ctx1 = c1.getContext("2d");
  var img1 = document.getElementById("pic1");
  ctx1.drawImage(img1,10,10);
  ctx1.lineWidth   = 2;
  ctx1.strokeStyle = "green";
  ctx1.globalAlpha = .60;
  ctx1.beginPath();
  ctx1.moveTo(10,10);
  ctx1.lineTo(120,10);
  ctx1.lineTo(120,290);
  ctx1.lineTo(10,290);
  ctx1.closePath();
  ctx1.stroke();
 </script>
</body>
</html>

我读过一些关于Chrome中带有加载图像或使用drawImage的bug的参考资料,但据我所见,这个bug显然已经修复了。(此外,这个HTML源代码在Chrome和Safari的本地文件中也会出现这个问题。)

我是错过了一些基本的东西还是做了些草率的事情?为什么这将与W3学校的编辑而不是在我自己的电脑上工作呢?

这是在W3学校的编辑:

在我将其复制并粘贴到本地文本编辑器中之后,将其保存为.html文件并加载到Chrome中(在Safari上是一样的):

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-11-21 15:11:57

我对此进行了实验,Alohci在评论中的回答证明是正确的。当我尝试我的页面的另一个答案(包括jQuery)时,它起了作用,我错误地认为这是正确的答案。我真正需要的是能够在地图上画线,所以我补充道:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
onload="doMaps()"

我的HTML标签。然后我加入了一个例行公事:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    function doMaps() {
        doMap15('Hybrid15Canvas', 'Hybrid15Image')
        doMap15('RoadMap15Canvas', 'RoadMap15Image')
        doMap16('Hybrid16Canvas', 'Hybrid16Image')
        doMap16('RoadMap16Canvas', 'RoadMap16Image')
    }

它把我所有的四张地图都装上并画上了线。它工作得非常完美,而且,它还可以处理从我的页面中删除的对jQuery的所有引用。这证明了jQuery是不必要的,只提供了加载时间。

由于没有其他人写出这个答案,我认为最好是向今后处理这一问题的任何人澄清。关于jQuery的答案可能有用(对我来说是这样),但可能行不通。

使用onload处理程序确实有效。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26989405

复制
相关文章
使用Fiddler对Android手机抓包
由于智能手机权限限制,使用传统方法在 Android 手机上抓包不得不对系统进行 root ,并且最终需要导出到电脑查看以及分析。相较而言,使用 Fiddler 辅助抓包操作简单易行,并且无需对手机进行 root ,同时兼容 Android 以及 IOS。使用 Fiddler 需要一台与被抓包手机处在同一局域网下的电脑辅助,并且路由器没有开启 AP 隔离。
reizhi
2022/09/26
9070
使用Fiddler对Android手机抓包
[ JavaScript ] 对闭包的理解和使用场景
首先,闭包是 JavaScript 这个语言的一个特点,主要的使用场景就是为了创建私有的变量。当然这个变量包含函数。
GavinUI
2021/04/10
1.4K0
[ JavaScript ] 对闭包的理解和使用场景
当使用junit4 对spring框架中各层进行测试时,需要添加的配置
当使用junit4 对spring框架中controller/service/mapper各层进行测试时,需要添加的配置
Theone67
2019/11/21
9420
spring之在配置Bean时如何关联不同的Bean
我们也可以在bean的内部配置相应的Bean,这个Bean就是一个内部bean,不能被外部使用。
西西嘛呦
2020/08/26
5990
spring之在配置Bean时如何关联不同的Bean
学习笔记:使用BurpSuite抓包时抓到火狐的包怎么办?
var xhr = new XMLHttpRequest(); xhr.open('get', 'https://v1.hitokoto.cn/'); xhr.onreadystatechange = function () { if (xhr.readyState === 4) { var data = JSON.parse(xhr.responseText); var hitokoto = document.getElementById('hitokoto'); hitokoto.innerText = data.hitokoto; } } xhr.send();
TRY博客-简单的网络技术
2022/09/08
1.6K0
学习笔记:使用BurpSuite抓包时抓到火狐的包怎么办?
使用webbench对不同的web服务器进行压力测试
1、webbench在linux下的安装步骤,如果安装过程失败,请检查当前用户的执行权限,如果报找不到某个目录的错,请自行创建指定的目录:
程序员一一涤生
2019/09/10
2.9K0
使用 React Hooks 时需要注意过时的闭包!
最近开源了一个 Vue 组件,还不够完善,欢迎大家来一起完善它,也希望大家能给个 star 支持一下,谢谢各位了。
前端小智@大迁世界
2021/03/04
1.9K0
使用Sentinel对Spring MVC接口进行限流
Spring Cloud Alibaba提供了中间件Sentinel,它以流量为切入点,提供了流量控制、熔断降级、系统负载保护等多个功能来保护服务的稳定性。今天就来尝试一下。
码农小胖哥
2020/10/10
2K0
使用Sentinel对Spring MVC接口进行限流
使用 AutoMapper 自动映射模型时,处理不同模型属性缺失的问题
使用 AutoMapper 可以很方便地在不同的模型之间进行转换而减少编写太多的转换代码。不过,如果各个模型之间存在一些差异的话(比如多出或缺少一些属性),简单的配置便不太行。本文帮助你解决这个问题。
walterlv
2023/10/23
6650
使用青花瓷对Android app 抓包
青花瓷window版本下载地址:http://www.pc6.com/softview/SoftView_426224.html
全栈程序员站长
2022/08/26
1.4K0
使用青花瓷对Android app 抓包
spring boot 使用 maven 打 jar 包配置
使用 ide 进行开发时,直接在ide上启动即可,如果要放到服务器上进行使用,就必须打成jar包,这里使用 maven 的打包插件进行打包。注意 <mainClass>com.devops.WebApplication</mainClass> 这行要改成你的启动类。
潇洒
2019/07/03
9730
spring boot 使用maven打jar包配置
使用 ide 进行开发时,直接在ide上启动即可,如果要放到服务器上进行使用,就必须打成jar包,这里使用 maven 的打包插件进行打包。注意 <mainClass>com.devops.WebApplication</mainClass> 这行要改成你的启动类。
潇洒
2023/10/20
2720
Spring MVC中使用header路由到不同方法
最近项目中需要针对URL进行统一化处理,其中有一条是需要根据不同的调用方提供不同的接口,但是实际上针对服务方来说,有的功能对所有渠道是一致的,有的功能是不同的。 一开始针对不同功能,我们也都放在同一个方法,但是随着渠道增多,以及不同渠道的差异增加,这种方式导致公共方法特别复杂。就连参数校验的逻辑就很长,也容易出错。 借用Spring MVC可以使用header路由的功能,我们实现了灵活的方法实现,针对一致性的功能,我们可以使用一个方法实现,有差异性的功能,可以路由到不同方法。而这些改动都对调用方透明,这样
十毛
2019/12/23
1.2K0
Spring 和 Mybatis 使用不同的数据源会怎样?
本篇文章要讨论的一个问题点, 给Spring和Mybatis设置不同的数据库数据源会怎样? 注意. 正常情况下一定要给Spring和Mybatis设置相同的数据库数据源. 案例代码位置 https:
书唐瑞
2022/06/02
5630
Spring 和 Mybatis 使用不同的数据源会怎样?
使用管家婆软件管理工厂对不同商品的价格
当企业自己的生产能力不足或者缺乏某种技术的话,就需要把某个工艺甚至整个产品交给外面的厂商去进行生产,要管理加工单位对不同商品的单价,可以参考下面说明的设置。
管家婆软件
2022/11/04
13.9K0
使用管家婆软件管理工厂对不同商品的价格
聊一聊使用Spring事物时不生效的场景
今天介绍一下Spring事物不生效的场景,事物是我们在项目中经常使用的,如果是Java的话,基本上都使用Spring的事物,不过Spring的事物如果使用不当,那么就会导致事物失效或者不回滚,最终导致数据不一致,所以很有必要去研究一下Spring事物不生效的一些场景,避免掉坑。
小四的技术之旅
2023/09/06
2250
聊一聊使用Spring事物时不生效的场景
Java 包的使用
指的是一个程序的目录,在最早的时候,如果要开发一个程序,只需要定义一个Java文件,而后在这个文件中编写所需要的类文件。
Mirror王宇阳
2020/11/12
9910
EMLOG通过不同域名使用不同的模板
只在emlog根目录的index.php简单修改就能实现,也可以做多用户二级域名调用不同的模板。当然也可以修改模板不同域名显示不同用户的文章。 $templet=Option::get('nonce_templet'); $the_host = $_SERVER['HTTP_HOST']; if ($the_host=='i.isiyuan.net') {////判断域名或者浏览器UA使用不同的前台模板 $templet='pink';//前台模板名 } define('TEMPLAT
Youngxj
2018/06/06
2.1K0
点击加载更多

相似问题

在Spring中使用不同的控制器包

10

在Spring中对多个包使用@ComponentScan时出错

119

如何在Spring中使用来自不同包的rest控制器?

23

Spring :使用@Autowire获取对不同spring实例的引用

11

对不同的版本使用不同的包iOS

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文