BOM

BOM : Browser Object Model 浏览器对象模型

Window对象

alert("系统提示框");
confirm("确认对话框");
prompt("输入对话框");

Location对象

Location 对象包含有关当前 URL 的信息
Location 对象是 window 对象的一部分,可通过 window.Location 属性对其进行访问

document.write(location.href) // 返回完整的URL
location.reload() // 重新载入当前文档

History对象

history对象是window对象的子对象,对应于浏览器的历史记录

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

history.back();
history.forward();

定时器

window.setInterval();   设置循环定时器
      var T = window.setInterval(test,1000);

window.clearInterval();  清除循环定时器
      window.clearInterval(T);

window.setTimeout();    设置单次定时器
      var T = setTimeout(test,1000);

window.clearTimeout()    清除单次定时器
      clearTimeout();

本地存储

// localStorage 永久存储
//设置缓存
localStorage.setItem('username', '张三')

//获取
console.log(localStorage.getItem('username'))

//删除指定key
localStorage.removeItem('username')

//清空
localStorage.clear()

// sessionStorage 关闭浏览器就没有了
sessionStorage.setItem('username', '李四')
console.log(sessionStorage.getItem('username'))
sessionStorage.removeItem('username')
sessionStorage.clear()

Cookie缓存对象

Cookie 是服务器保存在浏览器的一小段文本信息,每个 Cookie 的大小一般不能超过4KB。浏览器每次向服务器发出请求,就会自动附上这段信息

  • Cookie 保存以下几方面的信息
    • Cookie的名字
    • Cookie的值
    • 到期时间
    • 所属域名(默认是当前域名)
    • 生效的路径(默认是当前网址
//设置cookie
document.cookie = 'username=张三';

// 获取cookie
console.log(document.cookie)

//删除cookie
document.cookie = 'username=; max-age=0';

Cookie封装

cookie.html

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>cookie example</title>
    </head>
    <body>
        <script type="text/javascript" src="cookie.js" ></script>
        <script type="text/javascript">
            console.log('----------cookie对象-------------');
            console.log(cookie);

            console.log('----------对象-------------');
            console.log(cookie.getCookies());

            console.log('----------设置cookie-------------');
            console.log(cookie.set('name', 'wlh'));

            console.log('----------设置cookie 123-------------');
            console.log(cookie.set('name', 'wlh123'));

            console.log('----------设置cookie age-------------');
            console.log(cookie.set('age', 20));

            console.log('----------获取cookie-------------');
            console.log(cookie.get('name'));

            console.log('----------获取所有-------------');
            console.log(cookie.getCookies());

            console.log('----------清除age-------------');
            console.log(cookie.remove('age'));

            console.log('----------获取所有-------------');
            console.log(cookie.getCookies());

            console.log('----------清除所有-------------');
            console.log(cookie.clear());

            console.log('----------获取所有-------------');
            console.log(cookie.getCookies());

            console.log('----------解决冲突-------------');
            var $Cookie = cookie.noConflict(true /*a new name of cookie*/);
            console.log($Cookie);
            console.log('----------使用新的命名-------------');
            console.log($Cookie.getCookies());
        </script>
    </body>
</html>

cookie.js

/*
 * HTTP Cookie:存储会话信息
 * 名称和值传送时必须是经过RUL编码的
 * cookie绑定在指定的域名下,非本域无法共享cookie,但是可以是在主站共享cookie给子站
 * cookie有一些限制:比如IE6 & IE6- 限定在20个;IE7 50个;Opear 30个...所以一般会根据【必须】需求才设定cookie
 * cookie的名称不分大小写;同时建议将cookie URL编码;路径是区分cookie在不同情况下传递的好方式;带安全标志cookie
 *     在SSL情况下发送到服务器端,http则不会。建议针对cookie设置expires、domain、 path;每个cookie小于4KB
 * */
//对cookie的封装,采取getter、setter方式
(function(global){
    //获取cookie对象,以对象表示
    function getCookiesObj(){
        var cookies = {};
        if(document.cookie){
            var objs = document.cookie.split('; ');
            for(var i in objs){
                var index = objs[i].indexOf('='),
                    name = objs[i].substr(0, index),
                    value = objs[i].substr(index + 1, objs[i].length);    
                cookies[name] = value;
            }
        }
        return cookies;
    }
    //设置cookie
    function set(name, value, opts){
        //opts maxAge, path, domain, secure
        if(name && value){
            var cookie = encodeURIComponent(name) + '=' + encodeURIComponent(value);
            //可选参数
            if(opts){
                if(opts.maxAge){
                    cookie += '; max-age=' + opts.maxAge; 
                }
                if(opts.path){
                    cookie += '; path=' + opts.path;
                }
                if(opts.domain){
                    cookie += '; domain=' + opts.domain;
                }
                if(opts.secure){
                    cookie += '; secure';
                }
            }
            document.cookie = cookie;
            return cookie;
        }else{
            return '';
        }
    }
    //获取cookie
    function get(name){
        return decodeURIComponent(getCookiesObj()[name]) || null;
    }

    //清除某个cookie
    function remove(name){
        if(getCookiesObj()[name]){
            document.cookie = name + '=; max-age=0';
        }
    }

    //清除所有cookie
    function clear(){
        var cookies = getCookiesObj();
        for(var key in cookies){
            document.cookie = key + '=; max-age=0';
        }
    }
    //获取所有cookies
    function getCookies(name){
        return getCookiesObj();
    }
    //解决冲突
    function noConflict(name){
        if(name && typeof name === 'string'){
            if(name && window['cookie']){
                window[name] = window['cookie'];
                delete window['cookie'];
                return window[name];
            }
        }else{
            return window['cookie'];
            delete window['cookie'];
        }
    }
    global['cookie'] = {
        'getCookies': getCookies,
        'set': set,
        'get': get,
        'remove': remove,
        'clear': clear,
        'noConflict': noConflict
    };
})(window);

锚点跳转滑动效果

定时跳转

JS点名

文字动态

round

发光文字

powered by GitbookEdit Time: 2023-04-08 10:28:32