js 如何捕获window.print()的窗口完成后的事件

JavaScript019

js 如何捕获window.print()的窗口完成后的事件,第1张

捕获window.print()的窗口完成后的事件可按照一下操作尝试:

一、 第一种方法:

1、用document.execCommand来处理。

2、document.execCommand在执行完后会有返回值。

3、接着,就能判断:

(1)function CloseAfterPrint(){if(tata=document.execCommand("print")){window.close()}else setTimeout("CloseAfterPrint()",1000)}

(2)function DoSomeThing(){XXXX //your codeClostAfterPrint()}

二、 第二种方法:

用setTimeout()来控制javascript运行顺序:window.print()setTimeout("window.close()", 0)

<body>

<div>

<!--打印的内容-->

</div>

<input type="button" id="btn" value="打印" />

<script>

var oBtn = document.getElementById('btn')

oBtn.onclick = function(){

window.print()

}

</script>

</body>

在javascript中,可以为某个元素指定事件,指定的方式有以下三种:

1、在html中,使用onclick属性

2、在javascript中,使用onclick属性

(1)注意函数名没有双引号。

3、在javascipt中,使用addEvenListener()方法

三种方法的比较

(1)在第二、三种方法中,可以向函数传入一个event对象,并读取其相应属性,而方法一不可以。

一些语法细节

(1)在第一种方法中,onclick大小写无关,但在第二种方法中,必须使用小写。因为HMTL对大小写不敏感,而JS则会区分大小写。

(2)在第二、三种方法中,指定函数名时没有双引号,而第一种作为一个HTML属性,需要双引号。

(3)第一种方法需要括号,第二、三种不需要。

onclick="clickHandler()"

document.getElementById("jsOnClick").onclick = clickHandler2

document.getElementById("adEventListener").addEventListener("click",clickHandler2)