The window object

Variables and functions declared in the global scope become properties and methods of the window object. Global variables cannot be deleted by the DELETE operator, whereas properties defined directly on the window object can.

var age=29; function sayAge(){ alert(this.age); } alert(window.age); //29 sayAge(); //29 window.sayAge(); / / 29Copy the code

The age variable and sayAge() method are defined in the global scope, both of which belong to the window object.

var age=29; window.color="red"; delete window.age; delete window.color; alert(window.age); //29 alert(window.color); //undefinedCopy the code

As you can see, the global variable age cannot be removed, and the color attribute on the window object can be removed.

The window position

ScreenLeft and screenTop properties: Used to represent the position of the window relative to the left and top of the screen. ScreenX and screenY properties: Provide the same window location information. But they support different browsers. The following code takes the left and top positions of the window across browsers.

var leftPos=(typeof window.screenLeft=='number')? window.screenLeft:window.screenX; var topPos=(typeof window.screenTop=='number')? window.screenTop:window.screenY; document.write(leftPos+" "+topPos);Copy the code

The value is 0 in full screen. 0. MoveTo () and moveBy() move the window to a new position. MoveTo () accepts the X and Y values of the new position, while moveBy() accepts the number of pixels that have been moved horizontally and vertically. But it is now disabled in many browsers.

The window size

OuterWidth and outerHeight return the size of the browser window itself; The innerWidth and innerHeight represent the size (minus the border width) of the page view area in the container. Different browsers support different representations of window sizes, so browser compatibility also needs to be considered.

var pageWidth=window.innerWidth; var pageHeight=window.innerHeight; if(typeof pageWidth! ='number'){ if(document.compatMode=="CSS1Compat"){ pageWidth=document.documentElement.clientWidth; pageHeight=document.documentElement.clientHeight; }else{ pageWidth=document.body.clientWidth; pageHeight=document.body.clientHeight; } } document.write(pageWidth+" "+pageHeight);Copy the code

The resizeTo() and resizeBy() methods resize the browser window. ResizeTo () accepts the new width and height of the window, while resizeBy() accepts the difference between the width and height of the new window and the original window. But some browsers are now disabled as well.

Navigate and open Windows

The window.open() method takes four parameters: the URL to load, the window target, a property string, and a Boolean value indicating whether the new page replaces the currently loaded page in the browser history. The second argument can be: _self,_blank,_parent,_top. The third argument can be some window property, such as width, height, and so on. window.open(” “,’myWin’,’width=200,height=200,top=100,left=50′); The window.close() method is used to close a window. Verify that pop-ups are masked:

var bloked=false; try{ var wroxWin=window.open("http://www.baidu.com",'_blank'); if(wroxWin==null){ bloked=true; } }catch(ex){ bloked=true; } if(bloked){ alert("The popup was bloked!" ); }Copy the code

Intermittent and timeout calls

The setTimeout() method takes two parameters: the code to execute and the time in milliseconds. The clearTimeout() method is to cancel the timeout call.

var oBtn=document.getElementById('btn'); var timeoutId=setTimeout(function(){ alert("hello!" ); }, 1000); clearTimeout(timeoutId);Copy the code

The method for setting intermittent calls is setInterval(). It also takes the code to execute and the time in milliseconds.

var num=0; var max=10; var intervalId=null; function incrementNumber(){ num++; if(num==max){ clearInterval(intervalId); alert("Done!" ); } } intervalId=setInterval(incrementNumber,1000); var num=0; var max=10; function incrementNumber(){ num++; if(num<max){ setTimeout(incrementNumber,1000); }else{ alert("Done!" ); } } setTimeout(incrementNumber,1000);Copy the code

Both expressions have the same effect. However, it is best not to use intermittent calls.

System dialog box

The alert(),confirm(), and prompt() methods call the system dialog box to display information to the user.

var result=prompt("What is your name?" ); if(result){ alert("welcome,"+result); //welcome,... }Copy the code

Location object

The query string parameter is often used during development.

Function getQueryStringArgs(){var qs=(location.search.length >0? The location. The search. The substring (1) : "); Arg ={}; var items=qs.length? Qs.split ('&'):[], item=null, name=null, // use I =0, len=items.length; // Add each item one by one to the args object for(I =0; i<len; i++){ item=items[i].split("="); name=decodeURIComponent(item[0]); value=decodeURIComponent(item[1]); if(name.length){ args[name]=value; } } return args; }Copy the code

For example, what is the string to be queried? q=javascript&num=10

var args=getQueryStringArgs(); alert(args["q"]); //javascript alert(args["num"]); / / 10Copy the code

Position operation

location.assign("http://www.baidu.com"); window.location="http://www.baidu.com"; location.href="http://www.baidu.com"; These three expressions all have the same effect, open baidu's web page. In addition to modify the location of the hash, search, the hostname, the pathname, the port attribute can change the current page loading. Assume that the initial URL for HTTP: / / http://www.baidu.com/win/ / / is amended as: http://www.baidu.com/win/#section1 location. The hash = "# section1"; / / is amended as: http://www.baidu.com/win/?q=JavaScript location. Search = "? Q = javascript "; / / is amended as: http://www.yahoo.com/win/ location. The hostname = "www.yahoo.com" / / is amended as: http://www.baidu.com/win/mydir location. The pathname = "mydir / / is amended as:" http://www.baidu.com:8080/win/ location. The port = "8080"Copy the code

Replace () sets the URL exactly the same as the href attribute or assign for location, but it removes the URL from the address list of the history object, making it impossible for functions like Go or back to navigate. The reload() function is used to reload the currently displayed page. It is generally best to place reload() on the last line of code.

The history object

The most commonly used in history() is the go() method. Go (1) Forward two pages: history.go(2) You can also specify the page to jump to: history.go(” URL “), back: history().back(), forward: History. The forward ().