深入学习JavaScript中的bom


Posted in Javascript onMay 27, 2019

BOM(Broswer Object Model)

凡是 window 的属性和方法,均可以省略“window.”

方法:

框窗

1.警告框

window.alert("msg");

2.确认框

window.confirm("msg");

3.询问框

window.prompt("msg","defaulvalue")

页面

1.打开一个窗口

window.open()

2.在子窗口中使用,表示父窗口的window对象

window.opener

window.opener.fatherSayHello(); 调用父窗口的方法
window.opener.a

3.关闭当前窗口

window.close()

window.close(); 关闭当前
window.opener.close(); 关闭父窗口

定时任务

1.定时任务

var taskid = window.setTimeout(function,ms);
window.setTimeout("alert('hello!')", 5000);

2.间隔执行任务

var taskid = window.setInteval(function,ms);

3.清除定时任务

window.clearTimeout(taskid);

4.清除间隔执行任务

window.clearInteval(taskid);

打印屏幕

//长*宽
console.log(screen.width + "*" + screen.height)

后退

window.history.back();

前进

window.history.forward();

刷新

window.location.reload();//刷新
window.location.href = window.location.href;//刷新

Go 前进(x)步,后退(x)步,刷新(0),

window.history.go(x)

链接

window.location.href = http://www.baidu.com;

用户代理 浏览器内核

console.log(window.navigator.userAgent)

框窗

//凡是window的属性和方法,均可以省略“window.”
<script type="application/javascript">
// 警告框
function testAlert(){
var result=window.alert("这是一个警告框")
console.log(result);
}
// confirm 确认框
function testConfirm(){
var result =window.confirm("你确认要离开了吗?");
if(result){
alert("欢迎下次再来!")
}else{
alert("那你在逛逛吧!")
}
consol.log(result);
}
// prompt 询问框
function testPrompt(){
var result = window.prompt("请输入U盾密码","例如:123456");
console.log(result);
}
</script>
<body>
<button onclick="testAlert();">testAlert</button>
<button onclick="testConfirm();">testConfirm</button>
<button onclick="testPrompt();">testPrompt</button>
</body>

页面

//子页面
<script type="application/javascript">
function sayHello(){
alert("hello world")
}
//打开一个窗口
function callFatherMethod(){
window.opener.fatherSayHello();
window.opener.a
}
//关闭本窗口
function testClose(){
window.close();
}
//关闭父窗口
function testFatherClose(){
window.opener.close();
}
</script>
<body>
<button onclick="callFatherMethod()">调用父窗口的方法</button>
<button onclick="testClose()">关闭本窗口</button>
<button onclick="testFatherClose()">关闭父窗口</button>
</body>
//父页面
<script type="application/javascript">
var a = 10;
window.onload = function(){
console.log(window);
console.log("11111111111")
}
//打开一个新窗口
function testOpen(){
var sonwindow = window.open("son.html","aaa","height=300,width=500,top=50,left=50,toolbar=no,menubar=no,scrollbars=no,resizable=no,location=no,status=no")
//子窗口的window对象
console.log(sonwindow);
}
function fatherSayHello(){
alert("hello son!");
}
</script>
<body>
<button onclick="testOpen();">打开一个新窗口</button>
</body>

定时任务

<script type="application/javascript">
function setTime() {
// window.setTimeout("alert('hello!')",5000);
window.setTimeout(sayHello, 5000);
}
var sayHello = function () {
alert("你好!");
}
</script>
</head>
<body>
<button onclick="sayHello();">调用sayHello</button>
<button onclick="setTime();">调用setTime</button>

间隔执行任务

<script type="application/javascript">
/*
window.onload = function(){
window.setTimeout(closeSelf, 1000);
}
function closeSelf() {
var secval = document.getElementById("sec").innerHTML;
var secint = parseInt(secval);
document.getElementById("sec").innerHTML = --secint;
if(secint == 0){
window.close();
}
window.setTimeout(closeSelf, 1000);
}
*/

var taskid = 0;
window.onload = function(){
//间隔执行任务,间隔 1000ms 执行一次
taskid = window.setInterval(closeSelf, 1000);
}
function closeSelf() {
//获取 10s 
var secval = document.getElementById("sec").innerHTML;
console.log(secval);
var secint = parseInt(secval);
console.log(secint);
//10s 减减
document.getElementById("sec").innerHTML = --secint;
if(secint == 0){
window.close();
}
}
// 4.清除间隔执行任务 暂停
function stopTask(){
window.clearInterval(taskid);
}
//继续计时
function goonTask(){
taskid = window.setInterval(closeSelf, 1000);
console.log(taskid)
}
</script>
<body>
付款成功,页面将在<span id="sec">10</span>s后关闭。
<button onclick="stopTask()">稍等,待会我会自己关闭</button>
<button onclick="goonTask()">继续读秒,关闭窗口</button>
</body>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js压缩工具 yuicompressor 使用教程
Mar 31 Javascript
解决IE下select标签innerHTML插入option的BUG(兼容IE,FF,Opera,Chrome,Safari)
May 13 Javascript
Flash图片上传组件 swfupload使用指南
Mar 14 Javascript
使用JQuery FancyBox插件实现图片展示特效
Nov 16 Javascript
浅谈Angularjs link和compile的使用区别
Oct 21 Javascript
Vue.js仿微信聊天窗口展示组件功能
Aug 11 Javascript
详解React Native顶|底部导航使用小技巧
Sep 14 Javascript
javascript变量提升和闭包理解
Mar 12 Javascript
基于Koa2写个脚手架模拟接口服务的方法
Nov 27 Javascript
express.js中间件说明详解
Mar 19 Javascript
JS实现简单tab选项卡切换
Oct 25 Javascript
使用Vant完成DatetimePicker 日期的选择器操作
Nov 12 Javascript
Vue实现根据hash高亮选项卡
May 27 #Javascript
vue使用localStorage保存登录信息 适用于移动端、PC端
May 27 #Javascript
Vue使用localStorage存储数据的方法
May 27 #Javascript
了解javascript中的Dom操作
May 27 #Javascript
Vue项目使用localStorage+Vuex保存用户登录信息
May 27 #Javascript
vue cli3.0 引入eslint 结合vscode使用
May 27 #Javascript
深入浅出了解Node.js Streams
May 27 #Javascript
You might like
体育彩票排列三组选三算法分享
2014/03/07 PHP
PHP中set error handler函数用法小结
2015/11/11 PHP
摘自启点的main.js
2008/04/20 Javascript
基于jQuery架构javascript基础体系
2011/01/01 Javascript
js实现select跳转菜单新窗口效果代码分享(超简单)
2015/08/21 Javascript
jquery 实现输入邮箱时自动补全下拉提示功能
2015/10/04 Javascript
JS验证图片格式和大小并预览的简单实例
2016/10/11 Javascript
js+css3制作时钟特效
2016/10/16 Javascript
Bootstrap缩略图与警告框学习使用
2017/02/08 Javascript
react-router中的属性详解
2017/06/01 Javascript
javaScript产生随机数的用法小结
2018/04/21 Javascript
javascript实现blob加密视频源地址的方法
2019/08/08 Javascript
小程序和web画三角形实现解析
2019/09/02 Javascript
[09:40]DAC2018 4.5 SOLO赛 MidOne vs Miracle
2018/04/06 DOTA
python动态加载变量示例分享
2014/02/17 Python
分享Python字符串关键点
2015/12/13 Python
python 实现红包随机生成算法的简单实例
2017/01/04 Python
python爬虫 正则表达式使用技巧及爬取个人博客的实例讲解
2017/10/20 Python
基于Python中单例模式的几种实现方式及优化详解
2018/01/09 Python
Selenium鼠标与键盘事件常用操作方法示例
2018/08/13 Python
python实现随机漫步方法和原理
2019/06/10 Python
python中的Elasticsearch操作汇总
2019/10/30 Python
python Matplotlib数据可视化(2):详解三大容器对象与常用设置
2020/09/30 Python
python读写数据读写csv文件(pandas用法)
2020/12/14 Python
aec加密 php_php aes加密解密类(兼容php5、php7)
2021/03/14 PHP
Bibloo匈牙利:女装、男装、童装及鞋子和配饰
2019/04/14 全球购物
美国运动鞋类和服装零售连锁店:Shoe Palace
2019/08/13 全球购物
工作时间上网检讨书
2014/02/03 职场文书
求职毕业生自荐书
2014/02/08 职场文书
竞选班长自荐书范文
2014/03/09 职场文书
小学生寒假家长评语
2014/04/16 职场文书
幼儿园园长新年寄语2015
2014/12/08 职场文书
大学毕业生个人总结
2015/02/28 职场文书
2015年市场部工作总结
2015/04/30 职场文书
对公司的意见和建议
2015/06/04 职场文书
Python装饰器详细介绍
2022/03/25 Python