JavaScript-BOM编程

简介: JavaScript-BOM编程

一、window.open和window.close


1、BOM编程中,window对象是顶级对象,代表浏览器窗口


2、window有open和close方法,可以开启窗口和关闭窗口


示例代码:


<body>
<input type="button" value="开启百度(新窗口)" onclick="window.open('http://www.baidu.com');" />
  <input type="button" value="开启百度当前窗口" onclick="window.open('http://www.baidu.com','_self');" />
  <input type="button" value="开启百度(新窗口)" onclick="window.open('http://www.baidu.com','_blank');" />
  <input type="button" value="开启百度(父窗口)" onclick="window.open('http://www.baidu.com','_parent');" />
  <input type="button" value="开启百度(顶级窗口)" onclick="window.open('http://www.baidu.com','_top');" />
  <input type="button" value="开启指定窗口" onclick="window.open('SSS-open窗口测试.html');" />
</body>


窗口测试.html


<body>
  <input type="button" value="关闭指定窗口" onclick="window.close();">
  </body>


二、弹出确认框


示例代码:


<body>
  <script type="text/javascript">
    function del(){
    /* var ok = window.confirm("亲,你确认删除此消息吗?");
    if(ok){
      alert("正在删除数据!");
    }
    } */
    //优化
    if(window.confirm("亲,你确认删除此消息吗?")){
    alert("正在删除数据!");
    }
    }
  </script>
  <input type="button" value="弹出警示框" onclick="window.alert('警示信息!');" /> 
  <!-- 删除操作的时候都要提前先得到用户的确认 -->
  <input type="button" value="弹出确认框(删除)" onclick="window.del();" /> 
  </body>


0a2653c851af460fa595bd959398a8f1.png2d65d23f6d4748949b924e4057485923.png6de278e6d6694ce5bb08e7e842b7e74b.png


三、如果当前窗口不是顶级窗口,将当前窗口设置为顶级窗口


核心语法:


if(window.top != window.self){
    window.top. location = window.self. location;
}

示例代码:


<body>
  <iframe src="007-顶级窗口测试页面.html" width="500px" height="500px"></iframe>
  </body>


顶级窗口测试页面.html:


<body>
  <script type="text/javascript">
    //如果当前这个窗口不是顶级窗口的话,将当前窗口设置为顶级窗口.
    function setTop(){
    //window是当前浏览器的窗口,代表007.html
    //"当前窗口的顶级窗口"如果"不是自己"
    //window.top就是当前窗口对应的顶级窗口
    //window.self表示当前自己这个窗口
    //window.top 是006窗口
    //window.self 是007窗口
    if(window.top != window.self){
      window.top.location = window.self.location;
      }
    }
  </script>
  007-html
  <input type="button" value="把不是顶级窗口的设置成顶级窗口" onclick="setTop();">
  </body>


8ec4f2997fb246878c34ecd6d122b7c6.png12c3b7f3f8814309a195c64f051d4445.png


四、历史记录


window.history.back();    window.history.go(-1);    window.history.go(1);


示例代码:


<body>
  <a href="004-history测试页面.html">004-history测试呀!</a>
  <!-- 前进不常用!!!!! -->
  <input type="button" value="前进" onclick="window.history.go(1)" />
  </body>


历史测试页面.html:


<body>
  004 page!
  <input type="button" value="后退" onclick="window.history.back();" />
  <input type="button" value="后退" onclick="window.history.go(-1);" />
  </body>


34e8d716411043c08c7ffba9fbba23de.png

92ba0822ed0b46e1ae72df8a17d3a45b.png


五、设置浏览器地址栏上的URL


跳转页面可以通过多种方式:(这些都是发送请求!!!!)

     第一种方式:直接在浏览器地址栏上写URL。(重点)


     第二种方式:可以点击超链接(重点)


     第三种方式:提交表单(重点)


     第四种方式:window.open(url,target) (了解)


     第五种方式:js代码(重点)


window.location.href

     window.location

     document.location.href

     document.location


通过浏览器向服务器发送请求,通常是以上的五种方式。只有form可以动态的修改数据!

示例代码:


<body>
  <script type="text/javascript">
    function goBaidu(){
    /* var locationS = window.location;
    locationS.href = "http://www.baidu.com"; */
    // window.location.href = "http://www.126.com";
    // window.location = "http://www.126.com";
    //document.location.href = "http://www.baidu.com";
    document.location = "http://www.baidu.com";
    }
  </script>
  <input type="button" value="百度" onclick="goBaidu();" />
  </body>

d79b274929334152a6d38be91e2d1be3.pngdfc80ca9d8004e6c9ddc00e8448ffc6a.png


相关文章
|
4月前
|
存储 JavaScript 前端开发
JavaScript编程实现tab选项卡切换的效果+1
JavaScript编程实现tab选项卡切换的效果+1
|
5月前
|
JavaScript 前端开发 编译器
解锁JavaScript模块化编程新纪元:从CommonJS的基石到ES Modules的飞跃,探索代码组织的艺术与科学
【8月更文挑战第27天】随着Web应用复杂度的提升,JavaScript模块化编程变得至关重要,它能有效降低代码耦合度并提高项目可维护性及扩展性。从CommonJS到ES Modules,模块化标准经历了显著的发展。CommonJS最初专为服务器端设计,通过`require()`同步加载模块。而ES Modules作为官方标准,支持异步加载,更适合浏览器环境,并且能够进行静态分析以优化性能。这两种标准各有特色,但ES Modules凭借其更广泛的跨平台兼容性和现代语法逐渐成为主流。这一演进不仅标志着JavaScript模块化的成熟,也反映了整个JavaScript生态系统的不断完善。
57 3
|
2月前
|
前端开发 JavaScript 持续交付
提高JavaScript编程效率
提高JavaScript编程效率
31 3
|
2月前
|
自然语言处理 JavaScript 前端开发
JavaScript闭包:解锁编程潜能,释放你的创造力
【10月更文挑战第25天】本文深入探讨了JavaScript中的闭包,包括其基本概念、创建方法和实践应用。闭包允许函数访问其定义时的作用域链,常用于数据封装、函数柯里化和模块化编程。文章还提供了闭包的最佳实践,帮助读者更好地理解和使用这一强大特性。
24 2
|
4月前
|
JavaScript 前端开发
JavaScript编程实现tab选项卡切换的效果
JavaScript编程实现tab选项卡切换的效果
|
4月前
|
JavaScript 前端开发
用JavaScript编程控制网页上checkbox选择状态:全选、全部取消、反选
用JavaScript编程控制网页上checkbox选择状态:全选、全部取消、反选
|
4月前
|
JavaScript 前端开发 安全
JavaScript编程实现字符和字符串翻转
JavaScript编程实现字符和字符串翻转
|
4月前
|
JavaScript 前端开发
用JavaScript编程定义二维数组并初始化,然后输出元素值
用JavaScript编程定义二维数组并初始化,然后输出元素值
|
5月前
|
JavaScript 前端开发 安全
揭秘TypeScript的魔力:它是如何华丽变身为JavaScript的超能英雄,让您的代码飞入全新的编程维度!
【8月更文挑战第22天】在Web开发领域,JavaScript是最主流的编程语言之一。但随着应用规模的增长,其类型安全和模块化的不足逐渐显现。为解决这些问题,微软推出了TypeScript,这是JavaScript的一个超集,通过添加静态类型检查来提升开发效率。TypeScript兼容所有JavaScript代码,并引入类型注解功能。
43 2
|
5月前
|
JavaScript 前端开发 Oracle