



下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第利用JavaScript獲取用戶IP屬地方法詳解目錄寫在前面嘗試一:navigator.geolocation嘗試二:sohu的接口嘗試三:百度地圖的接口寫在后面
寫在前面
想要像一些平臺(tái)那樣顯示用戶的位置信息,例如某省市那樣。那么這是如何做到的,據(jù)說(shuō)這個(gè)位置信息的準(zhǔn)確性在通信網(wǎng)絡(luò)運(yùn)營(yíng)商那里?先不管,先實(shí)踐嘗試下能不能獲取。
嘗試一:navigator.geolocation
嘗試了使用navigator.geolocation,但未能成功拿到信息。
getGeolocation(){
if('geolocation'innavigator){
/*地理位置服務(wù)可用*/
console.log('地理位置服務(wù)可用')
navigator.geolocation.getCurrentPosition(function(position){
console.dir('回調(diào)成功')
console.dir(position)//沒(méi)有輸出
console.dir(position.coords.latitude,position.coords.longitude)
},function(error){
console.error(error)
}else{
/*地理位置服務(wù)不可用*/
console.error('地理位置服務(wù)可用')
}
嘗試二:sohu的接口
嘗試使用/cityjsonie=utf-8獲取用戶位置信息,成功獲取到信息,信息樣本如下:
{"cip":"1","cid":"440000","cname":"廣東省"}
//需要做跨域處理
getIpAndAddressSohu(){
//config是配置對(duì)象,可按需設(shè)置,例如responseType,headers中設(shè)置token等
constconfig={
headers:{
Accept:'application/json',
'Content-Type':'application/json;charset=UTF-8',
axios.get('/apiSohu/cityjsonie=utf-8',config).then(res={
console.log(res.data)//varreturnCitySN={"cip":"0","cid":"440000","cname":"廣東省"};
constinfo=res.data.substring(19,res.data.length-1)
console.log(info)//{"cip":"0","cid":"440000","cname":"廣東省"}
this.ip=JSON.parse(info).cip
this.address=JSON.parse(info).cname
}
調(diào)試的時(shí)候,做了跨域處理。
proxy:{
'/apiSohu':{
target:'/',//localhost=target
changeOrigin:true,
pathRewrite:{
'/apiSohu':'/'
}
下面是一張獲取到位置信息的效果圖:
嘗試三:百度地圖的接口
需要先引入百度地圖依賴,有一個(gè)參數(shù)ak需要注意,這需要像管理方申請(qǐng)。例如下方這樣
scriptsrc="/apiv=2.0ak=3ufnnh6aD5CST"/script
getLocation(){/*獲取當(dāng)前位置(瀏覽器定位)*/
const$this=this;
vargeolocation=newBMap.Geolocation();//返回用戶當(dāng)前的位置
geolocation.getCurrentPosition(function(r){
if(this.getStatus()==BMAP_STATUS_SUCCESS){
$this.city=r.address.city;
console.log(r.address)//{city:'廣州市',city_code:0,district:'',province:'廣東省',street:'',…}
}
functiongetLocationBaiduIp(){/*獲取用戶當(dāng)前位置(ip定位)*/
functionmyFun(result){
constcityName=;
console.log(result)//{center:O,level:12,name:'廣州市',code:257}
varmyCity=newBMap.LocalCity();
myCity.get(myFun);
}
成功用戶的省市位置,以及經(jīng)緯度坐標(biāo),但會(huì)先彈窗征求用戶意見。
寫在后面
嘗試結(jié)果不太理想,sohu的接口內(nèi)部是咋實(shí)現(xiàn)的,這似乎沒(méi)有彈起像下面那樣的征詢用戶意見的提示。
而在navigator.geolocation和BMap.
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 木工責(zé)任協(xié)議書
- 培訓(xùn)師成長(zhǎng)必讀:28本經(jīng)典教材精要
- 鄉(xiāng)村社區(qū)公共設(shè)施使用協(xié)議
- 《胸部手術(shù)后的護(hù)理》課件
- 消防水源協(xié)議書
- 設(shè)計(jì)院加班合同協(xié)議
- 《缺失的記憶:探索未知為主題的》課件
- 車輛管理協(xié)議書范本
- 轉(zhuǎn)讓移動(dòng)擺攤車合同協(xié)議
- 普寧離婚協(xié)議書
- 西部計(jì)劃面試題目及答案
- 公文筐的測(cè)試題及答案
- 2025靜脈治療規(guī)范
- 航道、通航建筑物及航運(yùn)樞紐大壩運(yùn)行安全風(fēng)險(xiǎn)辨識(shí)評(píng)估管控指南
- 《測(cè)繪生產(chǎn)成本費(fèi)用定額》(2025版)
- 第11課《浪花》課件-2024-2025學(xué)年統(tǒng)編版語(yǔ)文一年級(jí)下冊(cè)
- 教師省骨干考試題及答案
- 幼教培訓(xùn)課件:《幼兒園思維共享的組織與實(shí)施》
- 《飼料添加劑》課件
- 中央2024年中國(guó)合格評(píng)定國(guó)家認(rèn)可中心招聘筆試歷年典型考點(diǎn)(頻考版試卷)附帶答案詳解
- 【公開課】跨學(xué)科實(shí)踐:制作簡(jiǎn)易桿秤(課件)-人教版八年級(jí)物理下冊(cè)
評(píng)論
0/150
提交評(píng)論