Javascript高级编程学习笔记(28)—— BOM(2)window对象2
今天讲一下window对象和浏览器导航,弹窗等有关的内容
导航和打开窗口
window.open() 用于导航到某个特定 url
该方法接收四个参数
1、url
2、窗口目标(当页面中有多个框架frame,用于指定哪个窗口打开第一个参数的url)
3、特性字符串(用于规定新窗口的相关特性)
4、新页面是否取代浏览器历史记录中当前页面
这个特性字符串有以下可选值
1、fullscreen 是否全屏(IE有效)
2、height 数值
3、left 数值
4、location 是否显示地址栏(该特性可能会被浏览器禁用)
5、menubar 是否显示菜单栏
6、resizable 是否可以拖动改变窗口大小
7、scrollbars 是否允许滚动条
8、status 是否显示状态栏
9、toolbar 是否显示工具栏
10、top 数值
11、width 数值
这些特性由 , 隔开
该方法返回新窗口的引用,通过该引用可以使用close、moveTo、moveBy、resizeTo、resizeBy来进一步操控
可以通过该返回值的opener属性访问调用window.open 方法的窗口
若将该属性设为null那么新打开的窗口和原来的窗口之间将无法进行通讯,且无法恢复
安全设置
由于该方法常被用于伪装成系统弹窗打广告,所以现代浏览器添加了许多安全测试
在刚才的特性中许多特性都被浏览器限制了,不能修改
比如显示地址栏等
所以这个方法现在并不常用
大家不用在意
定时器
setTimout、setInterval
大家都知道JS是一个单线程语言,那么这种延时调用是怎么实现的呢?
这就涉及到了事件循环等概念
后边介绍事件的时候再详细解释
系统对话框
浏览器有三种类型的对话框
可以通过三个方法来调用
1、alert 显示信息只有确定按钮
2、confirm 显示信息有确定、取消按钮 该方法有返回值即确定为true,取消为false
3、promt 让用户在该弹框中输入值,返回值为用户的输入,该方法两个参数(1、提示信息 2、弹窗中的文本输入框的提示信息placeholder)
PS、关于弹框还有一个关于谷歌的特性,如果JS执行时会打开多个弹窗,那么从第二个弹窗开始会有个复选框
让用户选择是否跳过后续的弹窗
以上就是关于JS中window对象的内容
Javascript高级编程学习笔记(28)—— BOM(2)window对象2的更多相关文章
- Javascript高级编程学习笔记(27)—— BOM(1)window对象1
ECMAScript是JS的核心 但是对于在浏览器中运行的JS,BOM显然才是真正的核心 我们知道JS是由三个部分组成的 BOM.DOM.ECMAScript 之前的文章我们主要介绍的是ECMAScr ...
- Javascript高级编程学习笔记(18)—— 引用类型(7)单体内置对象
什么是内置对象呢? js高级程序设计中给出的定义为:由ES规定不依赖于宿主环境的对象,这些对象在JS执行前就已经存在 前面我们介绍的引用类型都是内置对象 除了这些对象外ECMA还规定了两个单体内置对象 ...
- Javascript高级编程学习笔记(31)—— BOM(5)screen、history对象
screen对象 screen对象应该是BOM对象中最不常用的对象了 其主要用于提供客户端的显示能力信息 包括浏览器外部显示的信息,和像素的宽高等 这个对象的主要用于检测客户端能力,一般不会影响功能 ...
- Javascript高级编程学习笔记(30)—— BOM(4)navigator对象
window对象作为浏览器的全局对象.location对象保存了页面的url信息 那么navigator对象又有什么作用呢? navigator对象 该对象最早由 Netspace Navigator ...
- Javascript高级编程学习笔记(29)—— BOM(3)location对象
在JS中location是一个神奇的对象 它既是window对象的属性,也是document对象的属性 它的作用主要在于保存当前文档页面的信息,以及将 url 解析为独立的片段 location对象属 ...
- Javascript高级编程学习笔记(1)—— JS简介
此系列文章,用于记录所学,如有错误欢迎指出. Javascript组成 1.核心(ECMAScript) 2.文档对象模型(DOM) 3.浏览器对象模型(BOM) 1.核心(ECMAScript) E ...
- Javascript高级编程学习笔记(35)—— DOM(1)节点
DOM JS由三部分组成 1.BOM 2.DOM 3.ECMAScript ES和BOM在前面的文章已经介绍过了 今天开始JS组成的最后一部分DOM(文档对象模型) 我们知道,JS中的这三个部分实际上 ...
- Javascript高级编程学习笔记(3)—— JS中的数据类型(1)
前一段时间由于事情比较多,所以笔记耽搁了一段时间,从这一篇开始我会尽快写完这个系列. 文章中有什么不足之处,还望各位大佬指出. JS中的数据类型 上一篇中我写了有关JS引入的Script标签相关的东西 ...
- JavaScript高级编程学习笔记(第三章之一)
继续记笔记,JavaScript越来越有意思了. 继续... 第三章:JavaScript基础 ECMAScript语法在很大程度上借鉴了C和其它类似于C的语言,比如Java和Perl. 大小写敏感: ...
随机推荐
- 微信x5内核很鸡贼啊
最近在写一个支付项目,然后要打通微信和支付宝支付,本来后端联调的时候直接调用weixin://wxpay/bizpayurl?XXXX接口就行的,完全走着通,然后到项目验收了就炸了,点不进去了,最后改 ...
- 有关Lambda的一些思考
问题: What do lambda expressions do? Can we write all functions as lambda expressions? In what cases a ...
- IIS7如何实现访问HTTP跳转到HTTPS访问
感谢原文作者,为方便后期查阅转载,原文链接:https://www.cnblogs.com/xiefengdaxia123/p/8542737.html 通常情况下我们是用的都是http的路径,对于h ...
- skynet记录6:定时器
稍后填坑 kernel中,每一次时钟中断会trap到kernel code,这个时间间隔称之为jiffies,每秒钟发生的次数为HZ 如果是4核,分配到每个核就是HZ/4 cat /boot/conf ...
- 20175325 MyCP (课下作业,必做)
20175325 MyCP (课下作业,必做) 一.目录: 题目 设计思路 运行结果 码云链接 二.题目 编写MyCP.java 实现类似Linux下cp XXX1 XXX2的功能,要求MyCP支持两 ...
- js二分算法排序
var arr = [1,2,3,5,10,15,23,35,67,76,78,89,100];var len = arr.length;for (var i = 1; i < len; i++ ...
- 内核中hash表(以net_device为例)
下边函数实现将新的 net_device 设备插入到内核链表中 /* * Device list insertion */ static void list_netdevice(struct net_ ...
- Reveal Cards In Increasing Order LT950
In a deck of cards, every card has a unique integer. You can order the deck in any order you want. ...
- 获取Vue的实例方法
我们知道在new Vue({...})后,如果没有赋值给一个变量存储,我们很难拿到这个实例,Vue官方也没有提供Vue.getInstance方法,那我们就自己扩展个吧 Code: Vue.getIn ...
- python基础入门之对文件的操作
**python**文件的操作1.打开文件 打开文件:open(file,mode='r') file:操作文件的路径加文件名 #绝对路径:从根目录开始的 #相对路径:从某个路径开始 mode:操作文 ...