js与或非

JavaScript014

js与或非,第1张

(1)对于布尔值,只有都为true才返回true;

(2)对于不是布尔值的情况则:

        如果第一个操作数是对象,则返回第二个数

                        eg:var str = new Array() 

                        console.log(str&&8);//返回值为8

        如果第二个操作数是对象,则只有在第一个操作数的求值结果为true的情况下才会返回该对象。

        如果第两个操作数都是对象,则返回第二个数操作数。

        如果有一个操作数是null,则返回null。

                        eg: console.log(8&&null)//返回结果为null

        如果有一个操作数是NaN,则返回第NaN。

        如果第一个操作数是undefined,则返回undefined。

(1)对于布尔值,逻辑或是非常简单的,只要有一个true,就返回true;

(2)对于不是布尔值的情况则:

                 如果第一个操作数是对象,则返第一个操作数

                 如果第一个操作数的求值结果为false,则返回第二个操作数

                 如果两个操作数都是对象,则返回第一个操作数

                 如果两个操作数是null,则返回null

                 如果两个操作数是NaN,则返回NaN

                 如果两个操作数是undefined,则返回undefined

如果一个操作数是一个对象,返回false

如果一个操作数是一个空字符串,返回false

如果一个操作数是一个非空字符串,返回false

如果一个操作数是一个数值0,返回true

如果一个操作数是任意的非零字符,返回false

如果一个操作数是null,返回true

 如果一个操作数是NaN,返回true

如果一个操作数是undefined,返回true

注:逻辑与,逻辑非都是从左向右判断,谁的第一个逻辑判断为true就显示谁,只不过逻辑非必须两个都为true,而且谁是第一个false就显示谁。

优先级:非>与>或

例如

if( !a&!b || !c&d ){

// (a、b为false) 或者 (c为false,d为true )

}

浏览$location的实例代码我们不难发现,每次的url中都会带一个#,这是因为angularjs默认使用的是标签模式,它和html5模式有什么区别?

(1)标签模式

标签模式使用的是内部链接的技巧,URL后面紧跟一个#,angularjs本身不会重写标签,也不需要服务器端的支持,链接后的URL样子基本是这样的:

(2)HTML5模式

标签模式的url看起来总是觉得不爽,html5模式可能比较适合咱们的请求格式(比如说REST),

在angularjs内部,可以通过$locationProvider.Html5Mode()(内部用的是html5 history api,如果浏览器不支持将自动降级到标签模式)方法来实现这样的路由要求,在该模式下,angularjs会重写标签。使用该模式时,永远都不要使用相对路径,如果你的应用是在根路径中加载的,这不会有什么问题,但如果是在其他路径中,AngularJS应用就无法正确处理路由了.

为了在应用程序各处使用相对链接,你将需要在你文档的里面设置一个.

注:html5 history api

history.pushState(data, title [, url]):往历史记录堆栈顶部添加一条记录;data会在onpopstate事件触发时作为参数传递过去;title为页面标题,当前所有浏览器都会忽略此参数;url为页面地址,可选,缺省为当前页地址。

history.replaceState(data, title [, url]) :更改当前的历史记录,参数同上。

history.state:用于存储以上方法的data数据,不同浏览器的读写权限不一样。

浏览器支持情况(完整的可以通过www.caniuse.com查询)

IE 10+, FF38+,chrome 31+,safari 7.1+, opera 30+

为什么要用history api?

无法使用浏览器的前进、后退来切换前后数据。

当我们将浏览器地址栏中的链接与朋友分享时,可能实际上却并非我们期望的内容。

单纯地使用AJAX不利于搜索引擎优化。