09.JavaScirpt window

  • window 窗口

  1. 所有浏览器都支持window对象,它表示浏览器窗口本身;
  2. 所有 JavaScript 全局对象、全局函数以及全局变量均自动成为 window 对象的成员
  3. 全局变量是window对象的属性,全局函数是window对象的方法;
  4. document也是window对象的属性
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <style type="text/css">
            .code{
                color: gray;
                border: 1px solid gainsboro;
                font-size: 15px;
            }
            pre{
                margin: 1em 0em 1em -19em;
                font-family: "楷体";
            }
            .result{
                color: gray;
                background-color: ghostwhite;
                font-size: 16px;
                padding: 0.5em 1em;
            }
            h3{
                color: red;
            }
            .result span:first-child{
                display: block;
                float: left;
                width: 10em;
                color: black;
            }
        </style>
        <script type="text/javascript">
            function objDisplay(eleId,obj){
                if(typeof(eleId)!="string" || typeof(obj)!="object"){
                    alert("Function objDisplay() need the first parameter string and second object !")
                }else{
                    var ele = document.getElementById(eleId);
                
                    if(!ele || !obj){
                        alert("Please check the parameter !")
                    }else{
                        for(i in obj){
                            var div = document.createElement("div");
                            
                            for(var j=0;j<2;j++){
                                var span = document.createElement("span");
                                if(j==0) span.innerHTML = i+" : ";
                                else span.innerHTML = obj[i];
                                div.appendChild(span);
                            }
                        ele.appendChild(div);
                        }
                    }
                }               
            }
        </script>
    </head>
    <body>
        <ul>
            <li>
                <h3>window</h3>
                <h4>代码:</h4>
                <div class="code">
                    <pre>
                    //window属性和方法
                    var winDict = {
                        "windowWidth":window.innerWidth,
                        "windowHeight":window.innerHeight,
                        "window.open()":"打开新窗口",
                        "window.close()":"关闭当前窗口",
                        "window.moveTo()":"移动当前窗口",
                        "window.resizeTo()":"调整当前窗口的尺寸"
                    }
                    //涵盖所有浏览器的写法(浏览器的视口,不包括工具栏和滚动条)
                    var winHeight = window.innerHeight
                    ||document.documentElement.clientWidth
                    ||document.body.clientWidth;
                    
                    var winWidth = window.innerWidth
                    ||document.documentElement.clientWidth
                    ||document.body.clientWidth;
                    
                    objDisplay("winDict",winDict);
                    </pre>
                </div>              
                <h4>结果:</h4>
                <div id="winDict" class="result"></div>
                <hr />
                <script>
                    //window属性和方法
                    var winDict = {
                        "windowWidth":window.innerWidth,
                        "windowHeight":window.innerHeight,
                        "window.open()":"打开新窗口",
                        "window.close()":"关闭当前窗口",
                        "window.moveTo()":"移动当前窗口",
                        "window.resizeTo()":"调整当前窗口的尺寸"
                    }
                    //涵盖所有浏览器的写法(浏览器的视口,不包括工具栏和滚动条)
                    var winHeight = window.innerHeight
                    ||document.documentElement.clientWidth
                    ||document.body.clientWidth;
                    
                    var winWidth = window.innerWidth
                    ||document.documentElement.clientWidth
                    ||document.body.clientWidth;
                    
                    objDisplay("winDict",winDict);
                </script>
            </li>               
        </ul>       
    </body>
</html>
image.png

  • screen 屏幕

  1. window.screen 对象在实际写的时候,可以不写window;
  2. screen.availWidth/screen.availHeight 属性返回访问者屏幕的宽度/高度,以像素计,减去界面特性,比如窗口任务栏;
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <style type="text/css">
            .code{
                color: gray;
                border: 1px solid gainsboro;
                font-size: 15px;
            }
            pre{
                margin: 1em 0em 1em -19em;
                font-family: "楷体";
            }
            .result{
                color: gray;
                background-color: ghostwhite;
                font-size: 16px;
                padding: 0.5em 1em;
            }
            h3{
                color: red;
            }
            .result span:first-child{
                display: block;
                float: left;
                width: 10em;
                color: black;
            }
        </style>
        <script type="text/javascript">
            function objDisplay(eleId,obj){
                if(typeof(eleId)!="string" || typeof(obj)!="object"){
                    alert("Function objDisplay() need the first parameter string and second object !")
                }else{
                    var ele = document.getElementById(eleId);
                
                    if(!ele || !obj){
                        alert("Please check the parameter !")
                    }else{
                        for(i in obj){
                            var div = document.createElement("div");
                            
                            for(var j=0;j<2;j++){
                                var span = document.createElement("span");
                                if(j==0) span.innerHTML = i+" : ";
                                else span.innerHTML = obj[i];
                                div.appendChild(span);
                            }
                        ele.appendChild(div);
                        }
                    }
                }               
            }
        </script>
    </head>
    <body>
        <ul>
            <li>
                <h3>screen</h3>
                <h4>代码:</h4>
                <div class="code">
                    <pre>
                    //screen属性
                    var scrDict = {
                        "availWidth":window.screen.availWidth,
                        "windowHeight":screen.availHeight,
                    }
                    
                    objDisplay("winDict",scrDict);
                    </pre>
                </div>              
                <h4>结果:</h4>
                <div id="winDict" class="result"></div>
                <hr />
                <script>
                    //screen属性
                    var scrDict = {
                        "availWidth":window.screen.availWidth,
                        "windowHeight":screen.availHeight,
                    }
                    
                    objDisplay("winDict",scrDict);
                </script>
            </li>               
        </ul>       
    </body>
</html>
image.png

  • location 位置

  1. window.location 对象用于获得当前页面的地址 (URL),并可以把浏览器重定向到新的页面;
  2. window.location 对象在编写时可不使用 window 这个前缀;
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <style type="text/css">
            .code{
                color: gray;
                border: 1px solid gainsboro;
                font-size: 15px;
            }
            pre{
                margin: 1em 0em 1em -19em;
                font-family: "楷体";
            }
            .result{
                color: gray;
                background-color: ghostwhite;
                font-size: 16px;
                padding: 0.5em 1em;
            }
            h3{
                color: red;
            }
            .result span:first-child{
                display: block;
                float: left;
                width: 10em;
                color: black;
            }
            button{
                background-color: blueviolet;
                color: white;
                border: 2px solid plum;
                border-radius: 2em;
                padding: 0.5em;
                margin: 0.5em;
            }
            button:focus{
                color: bisque;
            }
        </style>
        <script type="text/javascript">
            function objDisplay(eleId,obj){
                if(typeof(eleId)!="string" || typeof(obj)!="object"){
                    alert("Function objDisplay() need the first parameter string and second object !")
                }else{
                    var ele = document.getElementById(eleId);
                
                    if(!ele || !obj){
                        alert("Please check the parameter !")
                    }else{
                        for(i in obj){
                            var div = document.createElement("div");
                            
                            for(var j=0;j<2;j++){
                                var span = document.createElement("span");
                                if(j==0) span.innerHTML = i+" : ";
                                else span.innerHTML = obj[i];
                                div.appendChild(span);
                            }
                        ele.appendChild(div);
                        }
                    }
                }               
            }
        </script>
    </head>
    <body>
        <ul>
            <li>
                <h3>location</h3>
                <h4>代码:</h4>
                <div class="code">
                    <pre>
                    //location属性
                    var lcaDict = {
                        "hostname":window.location.hostname,//返回 web 主机的域名
                        "pathname":location.pathname,//返回当前页面的路径和文件名
                        "port":location.port,//返回 web 主机的端口
                        "protocol":location.protocol,//返回所使用的 web 协议(http:// 或 https://)
                        "href":location.href,//属性返回当前页面的 URL
                    }
                    
                    objDisplay("lcaDict",lcaDict);
                    </pre>
                </div>              
                <h4>结果:</h4>
                <div id="lcaDict" class="result"></div>
                <!--location.assign() 方法加载新的文档-->
                <button onclick="location.assign('https://www.jianshu.com/')">Assign</button>
                <hr />
                <script>
                    //location属性
                    var lcaDict = {
                        "hostname":window.location.hostname,//返回 web 主机的域名
                        "pathname":location.pathname,//返回当前页面的路径和文件名
                        "port":location.port,//返回 web 主机的端口
                        "protocol":location.protocol,//返回所使用的 web 协议(http:// 或 https://)
                        "href":location.href,//属性返回当前页面的 URL
                    }
                    
                    objDisplay("lcaDict",lcaDict);
                </script>
            </li>               
        </ul>       
    </body>
</html>
image.png

  • history 历史

  1. history.back()方法加载历史列表中的前一个 URL,与在浏览器点击后退按钮相同;
  2. history.forward()方法加载历史列表中的下一个 URL,与在浏览器中点击按钮向前相同;
  3. window.history 对象在编写时可不使用 window 这个前缀
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .code{
                color: gray;
                border: 1px solid gainsboro;
                font-size: 15px;
            }
            pre{
                margin: 1em 0em 1em -19em;
                font-family: "楷体";
            }
            .result{
                color: gray;
                background-color: ghostwhite;
                font-size: 16px;
            }
            ul li h3{
                color: red;
            }
            button{
                background-color: blueviolet;
                color: white;
                border: 2px solid plum;
                border-radius: 2em;
                padding: 0.5em;
                margin: 0.5em;
            }
            button:focus{
                color: bisque;
            }
        </style>
    </head>
    <body>
        <ul>
            <li>
                <h3>history</h3>
                <h4>代码:</h4>
                <div class="code">
                    <pre>
                    &lt;button name="back" onclick="window.history.back()"&gt;back&lt;/button&gt;
                    &lt;button name="forward" onclick="history.forward()"&gt;forward&lt;/button&gt;
                    </pre>
                </div>
                <h4>结果:</h4>
                <div class="result">
                    <button name="back" onclick="window.history.back()">back</button>
                    <button name="forward" onclick="history.forward()">forward</button>
                </div>
            </li>
            <hr />
        </ul>
    </body>
</html>
image.png

  • Navigator 导航

  1. window.navigator 对象包含有关访问者浏览器的信息;
  2. window.navigator 对象在编写时可不使用 window 这个前缀
  3. 来自 navigator 对象的信息具有误导性,不应该被用于检测浏览器版本
    navigator 数据可被浏览器使用者更改;
    浏览器无法报告晚于浏览器发布的新操作系统;
  4. 使用对象来检测浏览器,例:由于只有 Opera 支持属性 "window.opera",可以据此识别出 Opera
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title></title>
        <style type="text/css">
            .code{
                color: gray;
                border: 1px solid gainsboro;
                font-size: 15px;
            }
            pre{
                margin: 1em 0em 1em -19em;
                font-family: "楷体";
            }
            .result{
                color: gray;
                background-color: ghostwhite;
                font-size: 16px;
                padding: 0.5em 1em;
            }
            h3{
                color: red;
            }
            .result span:first-child{
                display: block;
                float: left;
                width: 10em;
                color: black;
            }
        </style>
        <script type="text/javascript">
            function objDisplay(eleId,obj){
                if(typeof(eleId)!="string" || typeof(obj)!="object"){
                    alert("Function objDisplay() need the first parameter string and second object !")
                }else{
                    var ele = document.getElementById(eleId);
                
                    if(!ele || !obj){
                        alert("Please check the parameter !")
                    }else{
                        for(i in obj){
                            var div = document.createElement("div");
                            
                            for(var j=0;j<2;j++){
                                var span = document.createElement("span");
                                if(j==0) span.innerHTML = i+" : ";
                                else span.innerHTML = obj[i];
                                div.appendChild(span);
                            }
                        ele.appendChild(div);
                        }
                    }
                }               
            }
        </script>
    </head>
    <body>
        <ul>
            <li>
                <h3>navigator</h3>
                <h4>代码:</h4>
                <div class="code">
                    <pre>
                    //navigator属性
                    var navDict = {
                        "appCodeName":window.navigator.appCodeName,
                        "appName":navigator.appName,
                        "appVersion":navigator.appVersion,
                        "cookieEnabled":navigator.cookieEnabled,
                        "platform":navigator.platform,
                        "userAgent":navigator.userAgent,
                        "systemLanguage":navigator.systemLanguage,
                    }
                    
                    objDisplay("navDict",navDict);
                    </pre>
                </div>              
                <h4>结果:</h4>
                <div id="navDict" class="result"></div>
                <hr />
                <script>
                    //navigator属性
                    var navDict = {
                        "appCodeName":window.navigator.appCodeName,
                        "appName":navigator.appName,
                        "appVersion":navigator.appVersion,
                        "cookieEnabled":navigator.cookieEnabled,
                        "platform":navigator.platform,
                        "userAgent":navigator.userAgent,
                        "systemLanguage":navigator.systemLanguage,
                    }
                    
                    objDisplay("navDict",navDict);
                </script>
            </li>               
        </ul>       
    </body>
</html>
image.png

  • PopupAlert 消息框

  1. JavaScript中消息框有三种:警告框,确认框,提示框;
  2. 警告框alert(),警告框携带信息弹出,需点击"确认"按钮后,才能继续进行下一步操作;
  3. 确认框confirm(),确认框携带信息弹出,点击"确认"按钮后返回true,点击"取消"按钮后返回false
  4. 提示框prompt(),提示框携带信息弹出,且要求用户输入内容,若未输入或点击"取消"按钮,则返回null,若输入且点击"确定"按钮,则返回输入值
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .code{
                color: gray;
                border: 1px solid gainsboro;
                font-size: 15px;
            }
            pre{
                margin: 1em 0em 1em -19em;
                font-family: "楷体";
            }
            .result{
                color: gray;
                background-color: ghostwhite;
                font-size: 16px;
            }
            ul li h3{
                color: red;
            }
            button{
                background-color: blueviolet;
                color: white;
                border: 2px solid plum;
                border-radius: 2em;
                padding: 0.5em;
                margin: 0.5em;
            }
            button:focus{
                color: bisque;
            }
        </style>
    </head>
    <body>
        <ul>
            <li>
                <h3>PopupAlert</h3>
                <h4>代码:</h4>
                <div class="code">
                    <pre>
                    &lt;button name="alert" onclick="alert('Hello World !')"&gt;Alert&lt;/button&gt;
                    &lt;button name="confirm" onclick="confirmResult()"&gt;Confirm&lt;/button&gt;
                    &lt;button name="prompt" onclick="promptResult()"&gt;Prompt&lt;/button&gt;
                    </pre>
                </div>
                <h4>结果:</h4>
                <div class="result">
                    <button name="alert" onclick="alert('Hello World !')">Alert</button>
                    <button name="confirm" onclick="confirmResult()">Confirm</button>
                    <button name="prompt" onclick="promptResult()">Prompt</button>
                </div>
                <div class="result">
                    <p id="confirmRes">显示Confirm按钮点击后的结果!</p>
                    <p id="promptRes">显示Prompt按钮点击后输入的结果!</p>
                </div>
            </li>
            <hr />
            <script>
                function confirmResult(){
                    var result = confirm("Continue ?");
                    document.getElementById("confirmRes").innerHTML = result;
                }
                function promptResult(){
                    var result = prompt("Please input the infomation !");
                    document.getElementById("promptRes").innerHTML = result;
                }
            </script>
        </ul>
    </body>
</html>
test27.gif

  • timing 计时

  1. setTimeout(),定时任务,在多长时间后,执行一次,只执行一次;
  2. clearTimeout(),清除定时任务.
  3. setInterval(),重复任务,每隔多长时间,就执行一次,重复执行;
  4. clearInterval(),清除重复任务.
<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .code {
                color: gray;
                border: 1px solid gainsboro;
                font-size: 15px;
            }
            
            pre {
                margin: 1em 0em 1em -19em;
                font-family: "楷体";
            }
            
            .result {
                color: gray;
                background-color: ghostwhite;
                font-size: 16px;
            }
            
            ul li h3 {
                color: red;
            }
            
            button {
                background-color: blueviolet;
                color: white;
                border: 2px solid plum;
                border-radius: 2em;
                padding: 0.5em;
                margin: 0.5em;
            }
            
            button:focus {
                color: bisque;
            }
        </style>
    </head>

    <body>
        <ul>
            <li>
                <h3>timing</h3>
                <h4>代码:</h4>
                <div class="code">
                    <pre>
                    //定义全局变量
                    var initDate = "";
                    var nowDateAll = "";

                    //时钟
                    function dateDisRef() {
                        var now = new Date(); //定义当前时间
                        var dateAll = "";
                        //定义时间字典
                        var dateDict = {
                            "year": now.getFullYear(),
                            "month": now.getMonth() + 1,
                            "day": now.getDate(),
                            "hours": now.getHours(),
                            "minutes": now.getMinutes(),
                            "seconds": now.getSeconds()
                        }
                        //格式校验,不足十的,在前方补0
                        function checkDate(dateTime, dateDict) {
                            if(dateDict[dateTime] < 10) {
                                dateDict[dateTime] = "0" + dateDict[dateTime];
                            }
                        }
                        //日期展示
                        for(dateTime in dateDict) {
                            checkDate(dateTime, dateDict);
                            switch(dateTime) {
                                case "year":
                                case "month":
                                    dateAll += (dateDict[dateTime] + "-");
                                    break;
                                case "hours":
                                case "minutes":
                                    dateAll += (dateDict[dateTime] + ":");
                                    break;
                                case "day":
                                    dateAll += (dateDict[dateTime] + " ");
                                    break;
                                case "seconds":
                                    dateAll += dateDict[dateTime];
                                default:
                                    break;
                            }
                        }
                        document.getElementById("dateDis").innerHTML = dateAll;
                        nowDateAll = dateAll;
                        //只设置一次
                        if(initDate == "") {
                            //替换第一个空格为T,用来设置日历默认时间
                            initDate = dateAll.replace(" ", "T");
                        }
                        //定时任务,等待500ms,执行dateDisRef()方法,调用后再次等待500ms,再会进行下次调用,故刷新频率为1s
                        var timeOut = setTimeout('dateDisRef()', 500);
                    }
                    //调用方法
                    dateDisRef();

                    //设置日历默认时间为当前时间
                    document.getElementById("initDate").value = initDate;

                    //倒计时
                    var interval;

                    function timing() {
                        //获得日历时间,并进行格式转换
                        var calendarTime = document.getElementById("initDate").value.toString();
                        //进行同时区时间设置(防止时差问题,导致时间差错误),均设置为标准时区
                        var calendarDate = new Date(calendarTime + "Z");
                        //动态获取当前时间
                        var nowDate = new Date(nowDateAll + "Z");
                        //将时间差转化为s
                        var dateMius = (calendarDate - nowDate) / 1000;
                        //清除重复任务,防止生成多个
                        clearInterval(interval);
                        //定义重复任务,时间间隔1s
                        interval = setInterval(function() {
                            dateMius--;
                            var timingEle = document.getElementById("timing");
                            if(dateMius == 0) {
                                timingEle.innerHTML = "倒计时结束!";
                                timingEle.style.color = "red";
                                clearInterval(interval);
                            } else {
                                if(timingEle.style.color == "red") timingEle.style.color = "gray";
                                timingEle.innerHTML = dateMius + " S";
                            }
                        }, 1000);
                    }
                    </pre>
                </div>
                <h4>结果:</h4>
                <div class="result">
                    <p id="dateDis"></p>
                </div>
                <div class="result">
                    <input type="datetime-local" id="initDate" onchange="timing()" />
                    <p id="timing"></p>
                </div>
                <script>
                    //定义全局变量
                    var initDate = "";
                    var nowDateAll = "";

                    //时钟
                    function dateDisRef() {
                        var now = new Date(); //定义当前时间
                        var dateAll = "";
                        //定义时间字典
                        var dateDict = {
                            "year": now.getFullYear(),
                            "month": now.getMonth() + 1,
                            "day": now.getDate(),
                            "hours": now.getHours(),
                            "minutes": now.getMinutes(),
                            "seconds": now.getSeconds()
                        }
                        //格式校验,不足十的,在前方补0
                        function checkDate(dateTime, dateDict) {
                            if(dateDict[dateTime] < 10) {
                                dateDict[dateTime] = "0" + dateDict[dateTime];
                            }
                        }
                        //日期展示
                        for(dateTime in dateDict) {
                            checkDate(dateTime, dateDict);
                            switch(dateTime) {
                                case "year":
                                case "month":
                                    dateAll += (dateDict[dateTime] + "-");
                                    break;
                                case "hours":
                                case "minutes":
                                    dateAll += (dateDict[dateTime] + ":");
                                    break;
                                case "day":
                                    dateAll += (dateDict[dateTime] + " ");
                                    break;
                                case "seconds":
                                    dateAll += dateDict[dateTime];
                                default:
                                    break;
                            }
                        }
                        document.getElementById("dateDis").innerHTML = dateAll;
                        nowDateAll = dateAll;
                        //只设置一次
                        if(initDate == "") {
                            //替换第一个空格为T,用来设置日历默认时间
                            initDate = dateAll.replace(" ", "T");
                        }
                        //定时任务,等待500ms,执行dateDisRef()方法,调用后再次等待500ms,再会进行下次调用,故刷新频率为1s
                        var timeOut = setTimeout('dateDisRef()', 500);
                    }
                    //调用方法
                    dateDisRef();

                    //设置日历默认时间为当前时间
                    document.getElementById("initDate").value = initDate;

                    //倒计时
                    var interval;

                    function timing() {
                        //获得日历时间,并进行格式转换
                        var calendarTime = document.getElementById("initDate").value.toString();
                        //进行同时区时间设置(防止时差问题,导致时间差错误),均设置为标准时区
                        var calendarDate = new Date(calendarTime + "Z");
                        //动态获取当前时间
                        var nowDate = new Date(nowDateAll + "Z");
                        //将时间差转化为s
                        var dateMius = (calendarDate - nowDate) / 1000;
                        //清除重复任务,防止生成多个
                        clearInterval(interval);
                        //定义重复任务,时间间隔1s
                        interval = setInterval(function() {
                            dateMius--;
                            var timingEle = document.getElementById("timing");
                            if(dateMius == 0) {
                                timingEle.innerHTML = "倒计时结束!";
                                timingEle.style.color = "red";
                                clearInterval(interval);
                            } else {
                                if(timingEle.style.color == "red") timingEle.style.color = "gray";
                                timingEle.innerHTML = dateMius + " S";
                            }
                        }, 1000);
                    }
                </script>
            </li>
            <hr />
        </ul>
    </body>

</html>
image.png
test28.gif

  • cookie

  1. cookie 是存储于访问者的计算机中的变量。每当同一台计算机通过浏览器请求某个页面时,就会发送这个 cookie
  2. 名字 cookie
    当访问者首次访问页面时,他或她也许会填写他/她们的名字。名字会存储于 cookie 中。当访问者再次访问网站时,他们会收到类似 "Welcome John Doe!" 的欢迎词。而名字则是从 cookie 中取回的。
    密码 cookie
    当访问者首次访问页面时,他或她也许会填写他/她们的密码。密码也可被存储于 cookie 中。当他们再次访问网站时,密码就会从 cookie 中取回。
    日期 cookie
    当访问者首次访问你的网站时,当前的日期可存储于 cookie 中。当他们再次访问网站时,他们会收到类似这样的一条消息:"Your last visit was on Tuesday August 11, 2005!"。日期也是从 cookie 中取回的。
<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body onload="checkCookie()">
        <script>
            //设置cookie
            function setCookies(name,value,expiredays){
                var exdate = new Date();
                //设置失效日期
                exdate.setDate(exdate.getDate()+expiredays);
                //设置cookie格式 name=value;expires=exdate
                //escape()用来编码字符串 toGMTString()此日期会在转换为字符串之前由本地时区转换为 GMT时区
                document.cookie=name+"="+escape(value)+((expiredays==null)?"":(";expires="+exdate.toGMTString()));
            }
            
            //获取cookie
            function getCookies(name){
                //判断cookie的长度
                if(document.cookie.length>0){
                    //获取要获取cookie的起始位置
                    start = document.cookie.indexOf(name+"=");
                    //判断indexOf()搜索结果,无结果时为-1
                    if(start!=-1){
                        start = start+name.length+1;//设置起始值为=的位置
                        end = document.cookie.indexOf(";",start);//从起始值搜索到名字的结束
                        if(end==-1) end=document.cookie.length;//无失效日期,则取到尾
                        return unescape(document.cookie.substring(start,end));//解码截取的子字符串
                    }
                }
                return "";
            }
            
            //检查是否设置了cookie
            function checkCookie(){
                usrName = getCookies("usrName");//获取usrCookie
                //不为空弹出欢迎框
                if(usrName!=null && usrName!=""){
                    alert("Welcome again "+usrName+" !");
                }else{
                    //为空则弹出消息框,提示用户输入名字,并设置cookie
                    usrName=prompt("Please enter your name :","");
                    if(usrName!=null&&usrName!=""){
                        setCookies("usrName",usrName,30);
                    }
                }
            }
        </script>
    </body>
</html>              
test29.gif

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容

  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,397评论 0 17
  • JavaScript Window - 浏览器对象模型 浏览器对象模型 (BOM) 使 JavaScript 有能...
    hx永恒之恋阅读 451评论 0 3
  • <a name='html'>HTML</a> Doctype作用?标准模式与兼容模式各有什么区别? (1)、<...
    clark124阅读 3,468评论 1 19
  • 因为没有找到现成资源,我在断崖式渣网的摧残下,下了一天终于能看了,作为印度出品,里头自然少不了载歌载舞,跳脱...
    茫茫人海ol阅读 487评论 0 0
  • 《魔鬼经济学》2 史蒂夫 都伯纳 史蒂夫 列维特 激励制度的四种诱因 1.经济动机 钱 2.道德动机 让自己...
    宫晓杰阅读 240评论 0 0