JS中的BOM应用详解

本文我们住要和大家分享js中的bom应用详解,我们曾经讲过js由三部分组成,其中一个部分就是bom,用于对浏览器进行操作。这节课我们主要就来介绍bom。

BOM基础

我们先来看一个BOM的最基础功能:打开、关闭窗口:

     无标题文档     

登录后复制

open方法用于打开一个窗口,相对的close方法用于关闭一个窗口。这里我们可以用open方法实现一个应用:运行代码。

在这之前,我们要给大家补充一个关于document.write的小知识。

     无标题文档     

登录后复制

打开源码可以发现,当我们点击了按钮后,整个页面的源码就只剩下了“abc”——也就是说,如果document.write如果放在事件里面使用,会先将页面完全清空再重写。

可以看到,我们的运行代码案例,使用document.write方法是非常合适的:

     无标题文档    window.onload=function ()  {   var oTxt=document.getElementById('txt1');   var oBtn=document.getElementById('btn1');     oBtn.onclick=function ()   {    var oNewWin=window.open('about:blank', '_blank');      oNewWin.document.write(oTxt.value);   };  };      

登录后复制

其中_blank代表新打开一个窗口(在本窗口打开用_self),about:blank代表打开的是一个空白窗口,然后我们使用document.write向新窗口写入html,就可以在新窗口运行html代码了。

讲完open后,我们来说说close的一些问题。close的使用非常简单,使用window.close便可以执行关闭窗口的事件。但是在火狐浏览器下,是无法close一个用户打开的窗口,只有一个窗口是用open方法打开的时候才能用close方法关闭。

讲完open和close方法后,我们来说两个常用的属性:window.nevigator.userAgent和window.location。前者的作用是获取当前浏览器的版本信息,后者的作用是获取当前网页的地址(不仅可以读取,也可以赋值,可以通过修改location跳转当前网页的网址),大家可以使用一下看看返回的内容,这里就不再列举了。

尺寸及坐标

这里我们讨论一下JS关于尺寸和坐标的内容。

首先要提到的就是关于可视区尺寸的知识。什么是可视区尺寸呢?其实就是用户端能在屏幕上看到网页部分的尺寸。可视区的尺寸会随着窗口的大小而变化。

通过document.documentElement.clientWidth和document.documentElement.clientHeight可以获取当前页面可视区的宽度和高度。

     无标题文档    window.onload=function ()  {   var oBtn=document.getElementById('btn1');   oBtn.onclick=function ()   {    alert('宽:'+document.documentElement.clientWidth+'高:'+document.documentElement.clientHeight);   };  };       

登录后复制

效果如下:

JS中的BOM应用详解

此外针对可视区,还有一个属性叫scrollTop,也就是滚动距离,或者说是可视区到页面顶端的距离。

   无标题文档  document.onclick=function () {  //IE、FF  //alert(document.documentElement.scrollTop);   //chrome  //alert(document.body.scrollTop);   var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;   alert(scrollTop); };    

登录后复制

效果如下:

//这里有图

值得注意的是document.documentElement.scrollTop仅仅在ie下兼容,在chrome下的写法则为document.body.scrollTop,因此我们用||方法处理兼容问题。
常用方法和事件

这里我们尝试使用除fixed以外的另一种方法实现元素的固定定位(fixed在ie6下不兼容)。

这里我们再画一张图:

JS中的BOM应用详解

可以看得出,只要我们将黑线的长度计算出来,就可以将右下方的p块进行固定定位了。而黑线的长度正好等于可视区高度减去p块的offsetHeight。

     无标题文档    #p1 {width:200px; height:150px; background:red; position:absolute; right:0; bottom:0;}  body {height:2000px;}      window.onscroll=function ()  {   var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;   var op=document.getElementById('p1');  op.style.top=document.documentElement.clientHeight-op.offsetHeight+scrollTop+'px';  };     

登录后复制

效果如下:

JS中的BOM应用详解

可以看到我们的p块有轻微的抖动,因为onscroll函数一直在发生,每发生一次便会调用一次,所以会发生这种情况。此外还存在一个更严重的情况:如果我们改变窗口大小,p块并不会跟着走而是保持在原地,因此我们还要用到另一个事件——

window.onresize(页面大小改变时触发的事件:):

window.onscroll=window.onresize=function (){...}

登录后复制

最后我们来说说几个常用的系统对话框:

alert(“内容”) 警告框,没有返回值

confirm(“提问的内容”) 选择框,会给确定或取消选项,返回一个boolean

prompt(“提示文字”,”默认文字”) 会弹出一个可输入的文本框,返回值为输入的文本内容(字符串),不输入则为null

相关推荐:

Js操作BOM对象模型的详细介绍

JS中常见的Bom对象

对比Javascript中BOM与DOM区别与联系

以上就是JS中的BOM应用详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2787725.html

(0)
上一篇 2025年3月8日 18:14:45
下一篇 2025年2月25日 17:41:21

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • Js简单实现返回上一页简洁介绍

    利用javascript实现返回上一页的方法很简单只需要一行js代码就可以搞定,不太了解js返回上一页的小伙伴们可以来看看,学习学习哦! 不再废话直接上代码: window.history.go(-1);  //返回上一页window.hi…

    编程技术 2025年3月8日
    200
  • js的数据类型及JS基本数据类型具体有哪几种

    本文主要和大家分享js的数据类型及js基本数据类型具体有哪几种,希望能帮助到大家。 近期做一些项目的时候发现,自己的js基础还是不够扎实,再看一遍犀牛书,加深自己的理解和印象。所以从这篇文章开始,后面都是关于原生js的一些内容。 我们先介绍…

    编程技术 2025年3月8日
    200
  • 三种JavaScript定义函数方法

    本文主要和大家介绍javascript定义函数的三种实现方法的相关资料,希望通过本文大家能够掌握三种定义函数的方法,需要的朋友可以参考下,希望能帮助到大家。 JavaScript定义函数的三种实现方法 【1】正常方法 function pr…

    编程技术 2025年3月8日
    200
  • Javascript刷新页面方法及location.reload()用法介绍

    本文主要和大家介绍javascript刷新页面方法及location.reload()用法介绍,希望通过本文能帮助到大家,需要的朋友可以参考下,希望能帮助到大家。 Javascript刷新页面的几种方法: 1    history.go(0…

    编程技术 2025年3月8日
    200
  • nodejs通过代理proxy发送http请求request详解

    本文主要和大家介绍nodejs通过代理(proxy)发送http请求(request),具有一定的参考价值,有兴趣的可以了解一下,希望能帮助到大家。 有可能有这样的需求,需要node作为web服务器通过另外一台http/https代理服务器…

    编程技术 2025年3月8日
    200
  • html和jquery/js引用外部图片时出现403的问题如何解决

    本文主要和大家分享解决html-jquery/js引用外部图片时遇到看不了或出现403的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 解决方法如下所示: function showI…

    编程技术 2025年3月8日
    200
  • js中json对象和字符串相互转化操作实例

    本文主要和大家介绍js中json对象和字符串的理解及相互转化操作实现方法,结合实例形式分析了json对象与字符串的功能以及相互转换操作实现技巧,需要的朋友可以参考下,希望能帮助到大家。 var str=”{'strv':…

    编程技术 2025年3月8日
    200
  • javascript随机生成一定位数的密码代码教程

    随机生成一定位数的密码,有最小个数和最大个数,必须包含数字、大小写字母,和特殊字符比如(- _ #);本文主要和大家介绍了关于利用javascript如何随机生成一定位数的密码的相关资料,文中给出了详细的示例代码,对大家的学习或者工作具有一…

    编程技术 2025年3月8日
    200
  • javascript计算渐变色实例分享

    本文主要和大家介绍javascript计算渐变颜色的实例的相关资料,希望通过本文能帮助到大家,让大家理解掌握这部分内容,需要的朋友可以参考下,希望能帮助到大家。 javascript计算渐变颜色的实例 有时候,一个表格或者一片区域内,需要若…

    2025年3月8日
    200
  • Node.js测量HTTP所花费的时间

    了解和测量http时间有助于我们发现客户端到服务器或服务器到服务器之间的通信性能瓶颈。 本文介绍了http请求中的时间开销,并展示了如何在node.js中进行测量。 在我们开始了解HTTP时间开销之前,让我们来看一些基本的概念: IP(互联…

    2025年3月8日
    200

发表回复

登录后才能评论