利用JavaScript獲取用戶IP屬地方法詳解_第1頁
利用JavaScript獲取用戶IP屬地方法詳解_第2頁
利用JavaScript獲取用戶IP屬地方法詳解_第3頁
利用JavaScript獲取用戶IP屬地方法詳解_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

第利用JavaScript獲取用戶IP屬地方法詳解目錄寫在前面嘗試一:navigator.geolocation嘗試二:sohu的接口嘗試三:百度地圖的接口寫在后面

寫在前面

想要像一些平臺(tái)那樣顯示用戶的位置信息,例如某省市那樣。那么這是如何做到的,據(jù)說這個(gè)位置信息的準(zhǔn)確性在通信網(wǎng)絡(luò)運(yùn)營商那里?先不管,先實(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)//沒有輸出

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是配置對象,可按需設(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需要注意,這需要像管理方申請。例如下方這樣

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)的,這似乎沒有彈起像下面那樣的征詢用戶意見的提示。

而在navigator.geolocation和BMap.

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論