HTML页面跳转的五种方法分享。

162 篇文章 2 订阅

下面列了五个例子来详细说明,这几个例子的主要功能是:在5秒后,自动跳转到同目录下的hello.html(根据自己需要自行修改)文件。

1) html的实现

1

2

3

4

5

6

<head>

<!-- 以下方式只是刷新不跳转到其他页面 -->

<meta http-equiv="refresh" content="10">

<!-- 以下方式定时转到其他页面 -->

<meta http-equiv="refresh" content="5;url=hello.html">

</head>

优点:简单

缺点:Struts Tiles中无法使用

2) javascript的实现

1

2

3

4

5

6

<script language="javascript" type="text/javascript">

// 以下方式直接跳转

window.location.href="hello.html";

// 以下方式定时跳转

setTimeout("javascript:location.href="hello.html"", 5000);

</script>

优点:灵活,可以结合更多的其他功能

缺点:受到不同浏览器的影响

3) 结合了倒数的javascript实现(IE)

1

2

3

4

5

6

7

8

9

<span id="totalSecond">5</span>

<script language="javascript" type="text/javascript">

var second = totalSecond.innerText;

setInterval("redirect()", 1000);

function redirect(){

totalSecond.innerText=--second;

if(second<0) location.href="hello.html";

}

</script>

优点:更人性化

缺点:firefox不支持(firefox不支持span、div等的innerText属性)

3") 结合了倒数的javascript实现(firefox)

1

2

3

4

5

6

7

8

9

<script language="javascript" type="text/javascript">

var second = document.getElementById("totalSecond").textContent;

setInterval("redirect()", 1000);

function redirect()

{

document.getElementById("totalSecond").textContent = --second;

if (second < 0) location.href = "hello.html";

}

</script>

4) 解决Firefox不支持innerText的问题

1

2

3

4

5

6

7

8

<span id="totalSecond">5</span>

<script language="javascript" type="text/javascript">

if(navigator.appName.indexOf("Explorer") > -1){

document.getElementById("totalSecond").innerText = "my text innerText";

} else{

document.getElementById("totalSecond").textContent = "my text textContent";

}

</script>

5) 整合3)和3")

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<span id="totalSecond">5</span>

<script language="javascript" type="text/javascript">

var second = document.getElementById("totalSecond").textContent;

if (navigator.appName.indexOf("Explorer") > -1)  {

second = document.getElementById("totalSecond").innerText;

} else {

second = document.getElementById("totalSecond").textContent;

}

setInterval("redirect()", 1000);

function redirect() {

if (second < 0) {

location.href = "hello.html";

} else {

if (navigator.appName.indexOf("Explorer") > -1) {

document.getElementById("totalSecond").innerText = second--;

} else {

document.getElementById("totalSecond").textContent = second--;

}

}

}

</script>

来源:微点阅读  https://www.weidianyuedu.com

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在要分享的图片通过canvas添加水印图片,你可以使用以下步骤: 1. 获取要添加水印的图片和水印图片,可以使用Image对象加载图片。 2. 将要添加水印的图片绘制到canvas上,使用canvas的drawImage方法。 3. 将水印图片绘制到canvas上,使用canvas的drawImage方法。 4. 设置水印图片的透明度,使用canvas的globalAlpha属性。 5. 设置水印图片的位置,使用canvas的translate方法。 6. 保存canvas的状态,使用canvas的save方法。 7. 绘制水印图片,使用canvas的drawImage方法。 8. 恢复canvas的状态,使用canvas的restore方法。 9. 将canvas换为图片,使用canvas的toDataURL方法。 10. 将图片作为分享的图片,调用app的方法到微信界面。 以下是添加水印图片的示例代码: ``` // 获取要添加水印的图片和水印图片 var img = new Image(); img.src = '要添加水印的图片的URL'; var watermark = new Image(); watermark.src = '水印图片的URL'; // 等待图片加载完成 Promise.all([loadImage(img), loadImage(watermark)]).then(function(images) { var canvas = document.createElement('canvas'); canvas.width = img.width; canvas.height = img.height; // 将要添加水印的图片绘制到canvas上 canvas.getContext('2d').drawImage(images[0], 0, 0); // 将水印图片绘制到canvas上 var ctx = canvas.getContext('2d'); ctx.globalAlpha = 0.5; // 设置水印图片的透明度 ctx.translate(10, 10); // 设置水印图片的位置 ctx.save(); // 保存canvas的状态 ctx.drawImage(images[1], 0, 0); // 绘制水印图片 ctx.restore(); // 恢复canvas的状态 // 将canvas换为图片 var dataURL = canvas.toDataURL('image/png'); // 调用app的方法到微信界面 app.shareImage(dataURL); }); function loadImage(image) { return new Promise(function(resolve, reject) { image.onload = function() { resolve(image); }; image.onerror = function() { reject(new Error('Failed to load image ' + image.src)); }; }); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值