您好,登錄后才能下訂單哦!
這篇文章主要介紹angular中通過$location獲取路徑的示例分析,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
以下獲取與修改的 URL 以 ( http://172.16.0.88:8100/#/homePage?id=10&a=100 ) 為例
【一】獲取 (不修改URL)
//獲取當(dāng)前完整的url路徑 var absurl = $locationabsUrl(); //http://88:8100/#/homePage?id=10&a=100 // 獲取當(dāng)前url路徑(當(dāng)前url#后面的內(nèi)容,包括參數(shù)和哈希值): var url = $locationurl(); // 結(jié)果:/homePage?id=10&a=100 // 獲取當(dāng)前url的子路徑(也就是當(dāng)前url#后面的內(nèi)容,不包括參數(shù)) var pathUrl = $locationpath() //結(jié)果:/homePage //獲取當(dāng)前url的協(xié)議(比如http,https) var protocol = $locationprotocol(); //結(jié)果:http //獲取主機(jī)名 var localhost = $locationhost(); //結(jié)果:88 //獲取當(dāng)前url的端口 var port = $locationport(); //結(jié)果:8100 //獲取當(dāng)前url的哈希值 var hash = $locationhash() //結(jié)果:http://088 //獲取當(dāng)前url的參數(shù)的序列化json對象 var search = $locationsearch(); //結(jié)果:{id: "10", a: "100"}
【二】修改 (改變URL相關(guān)內(nèi)容)
//1 修改url的子路徑部分(也就是當(dāng)前url#后面的內(nèi)容,不包括參數(shù)): $locationurl('/validation'); //結(jié)果:http://88:8100/#/validation //2 修改url的哈希值部分 $locationhash('myhash4'); //結(jié)果:http://88:8100/#/homePage?id=10&a=100#myhash4 //3 修改url的參數(shù)部分(第一個參數(shù)表示url參數(shù)的屬性名,第二個參數(shù)是該屬性名的屬性值,如果是已有屬性名,則修改,如果不是已有屬性,則新增) $locationsearch('id','111') // 結(jié)果(修改參數(shù)值):http://88:8100/#/homePage?id=111&a=100 $locationsearch('ids','111') // 結(jié)果(新增ids參數(shù)): http://88:8100/#/homePage?id=111&a=100&ids=111 //一次性修改多個參數(shù) $locationsearch({id:'55','a':'66'}) //結(jié)果:http://88:8100/#/homePage?id=55&a=66#myhash4 //第一個值表示url參數(shù)的屬性名,如果是已有屬性名,則刪除該屬性,如果不是已有屬性,那就等于沒改過 $locationsearch('age',null)
【三】修改URL但不存入歷史記錄
在上面的修改url的方法的時候,每修改一次,url都會被存入歷史記錄,可以使用后退按鈕回到修改前的url,如果不想要這種效果,而僅僅是替換當(dāng)前的記錄,可以使用 $location.path('/validation').replace();
以上是“angular中通過$location獲取路徑的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。