js实现网页标题栏闪烁提示效果实例分析


Posted in Javascript onNovember 20, 2014

本文实例讲述了js实现网页标题栏闪烁提示效果的方法。分享给大家供大家参考。具体分析如下:

网页标题栏闪烁效果我们在一些聊天工具会常看到,像现在流量的聊天室,下面我们就来给大家总结一款实现网页标题栏闪烁提示代码,感兴趣可参考一下。

公司的项目中用到了这个新消息提示的效果,主要用于提示用户有新消息。具体实现代码如下:

var newMessageRemind={
_step: 0,
_title: document.title,
_timer: null,
//显示新消息提示
show:function(){
var temps = newMessageRemind._title.replace("【 】", "").replace("【新消息】", "");
newMessageRemind._timer = setTimeout(function() {
newMessageRemind.show();
//这里写Cookie操作
newMessageRemind._step++;
if (newMessageRemind._step == 3) { newMessageRemind._step = 1 };
if (newMessageRemind._step == 1) { document.title = "【
 】" + temps };
if (newMessageRemind._step == 2) { document.title = "【新消息】" + temps };
}, 800);
return [newMessageRemind._timer, newMessageRemind._title];
},
//取消新消息提示
clear: function(){
clearTimeout(newMessageRemind._timer );
document.title = newMessageRemind._title;
//这里写Cookie操作
}
};

调用显示新消息提示:newMessageRemind.show();
调用取消新消息提示:newMessageRemind.clear();

看了上面代码自己再进行优化一下,不管怎样,自己能吸收学习到就好了。:)我主要是觉得他代码里面 newMessageRemind 这字段用得太多了,看起来密密麻麻的,多不舒服啊,想着换一种小清新的方式展现出来,于是乎就有了下面的代码:

var newMessageRemind = function () { 
  var i = 0, 
    title = document.title, 
    loop; 
 
  return { 
    show: function () { 
      loop = setInterval(function () { 
        i++; 
        if ( i == 1 ) document.title = '【新消息】' + title; 
        if ( i == 2 ) document.title = '【 】' + title; 
        if ( i == 3 ) i = 0; 
      }, 800); 
    }, 
    stop: function () { 
      clearInterval(loop); 
      document.title = title; 
    } 
  }; 
} ();

是不是清新了很多呢?^_^

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title>放假啦!!!</title>
</head>
<body>
<button id="test">stop</button>
<script type="text/javascript">
var newMessageRemind = function () {
 var i = 0,
 title = document.title,
 loop;
 return {
 show: function () {
  loop = setInterval(function () {
  i++;
  if ( i == 1 ) document.title = '【新消息】' + title;
  if ( i == 2 ) document.title = '【 】' + title;
  if ( i == 3 ) i = 0;
  }, 800);
 },
 stop: function () {
  clearInterval(loop);
  document.title = title;
 }
 };
} ();
newMessageRemind.show();
document.getElementById('test').onclick = function () {
 newMessageRemind.stop();
};
</script>
</body>
</html>

继续分享一个

<script>
(function() {
  var OriginTitile = document.title, titleTime;
  document.addEventListener('visibilitychange', function() {
    if (document.hidden) {
      document.title = '死鬼去哪里了!';
      clearTimeout(titleTime);
    } else {
      document.title = '(つェ⊂)咦!又好了!';
      titleTime = setTimeout(function() {
        document.title = OriginTitile;
      },2000);
    }
  });
})();
</script>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript使用循环和分割来替换和删除元素实例
Oct 13 Javascript
深入理解JavaScript编程中的同步与异步机制
Jun 24 Javascript
Vue获取DOM元素样式和样式更改示例
Mar 07 Javascript
JavaScript ES6中export、import与export default的用法和区别
Mar 14 Javascript
JS实现队列的先进先出功能示例
May 10 Javascript
JS逻辑运算符短路操作实例分析
Jul 09 Javascript
jQuery+ajax实现批量删除功能完整示例
Jun 06 jQuery
使用Vue 实现滑动验证码功能
Jun 27 Javascript
使用typescript改造koa开发框架的实现
Feb 04 Javascript
JS如何把字符串转换成json
Feb 21 Javascript
基于node+websocket+html实现腾讯课堂聊天室聊天功能
Mar 04 Javascript
vue中组件通信详解(父子组件, 爷孙组件, 兄弟组件)
Jul 27 Javascript
javascript获取flash版本号的方法
Nov 20 #Javascript
Jquery对象和Dom对象的区别分析
Nov 20 #Javascript
深入理解javascript变量声明
Nov 20 #Javascript
javascript限制用户只能输汉字中文的方法
Nov 20 #Javascript
jQuery 中$(this).index与$.each的使用指南
Nov 20 #Javascript
jQuery提示效果代码分享
Nov 20 #Javascript
IE6浏览器中window.location.href无效的解决方法
Nov 20 #Javascript
You might like
php 生成文字png图片的代码
2011/04/17 PHP
php中AES加密解密的例子小结
2014/02/18 PHP
PHP创建自己的Composer包方法
2018/04/09 PHP
JavaScript 定义function的三种方式小结
2009/10/16 Javascript
JavaScript中setAttribute用法介绍
2013/07/20 Javascript
解析Javascript中中括号“[]”的多义性
2013/12/03 Javascript
JS中FRAME的操作问题实例分析
2014/10/21 Javascript
JavaScript实现三阶幻方算法谜题解答
2014/12/29 Javascript
多个js毫秒倒计时同时进行效果
2016/01/05 Javascript
详解使用angular-cli发布i18n多国语言Angular应用
2017/05/20 Javascript
vue-router 路由基础的详解
2017/10/17 Javascript
vue中rem的配置的方法示例
2018/08/30 Javascript
Vue.extend实现挂载到实例上的方法
2019/05/01 Javascript
微信小程序实现获取用户信息并存入数据库操作示例
2019/05/07 Javascript
layui实现checkbox的目录树tree的例子
2019/09/12 Javascript
简单了解vue中的v-if和v-show的区别
2019/10/08 Javascript
详解vue 组件
2020/06/11 Javascript
Python实现从url中提取域名的几种方法
2014/09/26 Python
基于Python代码编辑器的选用(详解)
2017/09/13 Python
python下实现二叉堆以及堆排序的示例
2017/09/29 Python
python OpenCV学习笔记之绘制直方图的方法
2018/02/08 Python
利用pyuic5将ui文件转换为py文件的方法
2019/06/19 Python
Django项目中实现使用qq第三方登录功能
2019/08/13 Python
Python Web框架之Django框架Form组件用法详解
2019/08/16 Python
关于keras.layers.Conv1D的kernel_size参数使用介绍
2020/05/22 Python
python如何更新包
2020/06/11 Python
用html5绘制折线图的实例代码
2016/03/25 HTML / CSS
HTML5实现音频和视频嵌入的方法
2018/08/22 HTML / CSS
Carmen Sol官网:购买果冻鞋、手袋和配件
2021/01/01 全球购物
校班主任推荐信范文
2013/12/03 职场文书
硕士生工作推荐信
2014/03/07 职场文书
2014年工程师工作总结
2014/11/25 职场文书
医院中层管理人员培训心得体会
2016/01/11 职场文书
《秦兵马俑》教学反思
2016/02/24 职场文书
详解MySQL InnoDB存储引擎的内存管理
2021/04/08 MySQL
python人工智能human learn绘图可创建机器学习模型
2021/11/23 Python