Showing content from https://lbs.qq.com/tool/component-geolocation.html below:
Website Navigation
å端å®ä½ç»ä»¶ | è
¾è®¯ä½ç½®æå¡
å
³äºå¾®ä¿¡7.0æ´æ°åé¨åæºåè°ç¨å®ä½ç»ä»¶å¤±è´¥çå
Œ
ç±äºå¾®ä¿¡7.0çæ¬å级äºå¯¹httpsçå®å
¨éå¶ï¼å¨å¾®ä¿¡7.0çæ¬å以ä¸çæ¬ä½¿ç¨httpå议访é®å®ä½ç»ä»¶ä¼å¯¼è´å®ä½å¤±è´¥ã
å¼åè
å¦éå°ä¸è¿°é®é¢ï¼è¯·åæ¢è³httpså议访é®ãç»æ¨å¸¦æ¥çä¸ä¾¿æ·±ææ±æï¼
å端å®ä½ç»ä»¶
å端å®ä½ç»ä»¶ï¼æ¨å¨ä¼å纯HTML5 Geolocationå®ä½è½åå¼±ï¼å®ä½æåçä¸é«çé®é¢ï¼æä¾ç®åãæç¨çæ¥å£å¸®å©ä¸å¡å±è·åç¨æ·å½åçä½ç½®ä¿¡æ¯ï¼éç¨æ·ææï¼ï¼ä»¥éä½å¼åææ¬ï¼æåå®ä½ç²¾å度ã
è°ç¨ç¤ºä¾ è°ç¨æ¹å¼ä¸
å¼å
¥å°è£
好çJS模åï¼è°èµ·å端å®ä½ç»ä»¶ï¼éè¿å°è£
å¥½çæ¥å£è·åä½ç½®ä¿¡æ¯ãç¸æ¯æ¹å¼äºæ¤æ¹å¼æ´å ç®åå¿«æ·ã
代ç å°å jså¼å
¥å°åï¼https://3gimg.qq.com/lightmap/components/geolocation/geolocation.min.js
åèç±»ï¼qq.maps.Geolocation æé 彿° 说æ qq.maps.Geolocation(key, referer) åæ°ï¼ key ï¼ å¿
å¡«ï¼å¼åå¯é¥(key)ï¼ç³è¯·å°å https://lbs.qq.com/dev/console/key/manage refererï¼ å¿
å¡«ï¼è°ç¨æ¥æºï¼ä¸è¬ä¸ºæ¨çåºç¨åç§°ï¼ä¸ºäºä¿é对æ¨çæå¡ï¼è¯·å¡å¿
å¡«åï¼ä¾å¦ï¼ referer=mapqq æ¹æ³ è¿åå¼ è¯´æ getLocation(sucCallback, errCallback, [options: {timeout: number, failTipFlag: boolean}]) è·åå½åæå¨å°çä½ç½®ï¼è°ç¨ä¸æ¬¡å³éæ°å®ä½ä¸æ¬¡ï¼å®ä½æ°æ®æ¯è¾ç²¾ç¡®ã
sucCallback为å®ä½æååè°å½æ°ï¼å¿
å¡«ï¼
errCallback为å®ä½å¤±è´¥åè°å½æ°ï¼éå¡«ï¼å¦æä¸å¡«ï¼è¯·è®¾ä¸ºnullï¼
options为å®ä½é项ï¼éå¡«ï¼å¯ä»¥éè¿timeoutåæ°è®¾ç½®å®ä½çè¶
æ¶æ¶é´ï¼é»è®¤å¼ä¸º10s; failTipFlag: æ¯å¦å¨å®ä½å¤±è´¥æ¶ç»åºæç¤ºå¼å¯¼ç¨æ·æå¼ææææå¼å®ä½å¼å
³ãï¼å³å°æ¯æï¼ getIpLocation(sucCallback, [errCallback]) ç«å³è·åå½åæå¨å°çä½ç½®ï¼éç¨äºé精确å®ä½åºæ¯ï¼æ¯IPå®ä½ï¼åå¸çº§å«ã
sucCallback为å®ä½æååè°å½æ°ï¼å¿
å¡«ï¼
errCallback为å®ä½å¤±è´¥åè°å½æ°ï¼éå¡«ã watchPosition(sucCallback) çå¬ä½ç½®ä¿¡æ¯çæ¹åï¼ç±»ä¼¼HTML5 GeolocationçwatchPositionã
sucCallback为å®ä½æååè°å½æ°ï¼å¿
å¡«ã clearWatch() æ¸
é¤çå¬ï¼ç±»ä¼¼HTML5 GeolocationçclearWatchã 宿´ç¤ºä¾ è°ç¨æ¹å¼äº éè¿å
åµä¸ä¸ªéèiframeçæ¹å¼è°ç¨è¯¥ç»ä»¶ï¼å端å®ä½ç»ä»¶å¨è·åå°ç¨æ·çç²¾åä½ç½®ä¿¡æ¯åï¼ä¼éè¿html5 postMessageçæ¹å¼åä¼ ç¨æ·çä½ç½®ä¿¡æ¯ï¼å¼åè
éè¦å¨èªå·±ç页é¢ä¸å®ç°ä¸ä¸ªçå¬å½æ°ã
å端å®ä½ç»ä»¶å¨å è½½å®åä¼èªå¨å¼å¯å¼æ¥å®ä½ï¼å®ä½æåæå¤±è´¥é½ä¼è§¦åmessageäºä»¶éç¥ä¸å¡è°ç¨æ¹ãå®ä½æéçèæ¶ä¸åºå®ï¼è·ç¨æ·å®é
ç客æ·ç«¯ç¯å¢æå
³ãæ£å¸¸æ
åµä¸å¨1-3sï¼ç½ç»è¾å·®æ¶éè¦æ¶é´è¾é¿ã
HTMLç»æ è°ç¨åæ° åæ°å å¿
å¡« åæ°è¯´æ ç¤ºä¾ key æ¯ å¼åå¯é¥ï¼keyï¼ key=your key
ç¹å«è¯´æï¼è¥æ¨çkey已设置webserviceååç½ååï¼è¯·å¨ç½åå ä¸å¢å æ¬ç»ä»¶åå effect å¦ å端å®ä½ç»ä»¶å¨å®ä½è¿ç¨ä¸çè§è§ææã
è¥ä½¿ç¨éèçiframeè°ç¨è¯¥ç»ä»¶ï¼å¯ä¸ä¼ è¯¥åæ° effect=zoomï¼å¼å¸ååå¨ç»(å¦ä¸å¾å·¦)
effect=circleï¼å½©è²ååå¨ç»(å¦ä¸å¾å³) referer æ¯ è°ç¨æ¥æºï¼ä¸è¬ä¸ºæ¨çåºç¨åç§°ï¼ä¸ºäºä¿é对æ¨çæå¡ï¼è¯·å¡å¿
å¡«åï¼ referer=myapp å¨ç¶é¡µé¢çå¬messageäºä»¶ å½å¨é¡µé¢ä¸åµå
¥å端å®ä½ç»ä»¶åï¼èªå¨è§¦åå端å®ä½ç»ä»¶ï¼å®ä½æ¶æ¯è¿ååï¼è§¦åçå¬äºä»¶ã
ç¹å«æéï¼å®ä½ç»ä»¶å¨é¦æ¬¡å®ä½æå æ 馿¬¡å®ä½å¤±è´¥åï¼è¿ä¼ç»§ç»å°è¯å®ä½ï¼å¦æåç»è·åå°ç²¾åº¦æ´é«çä½ç½®ä¿¡æ¯ï¼è¿ä¼ç»§ç»è§¦åç¶é¡µé¢æ¥æ¶å®ä½ä¿¡æ¯çmessageäºä»¶ãä¸å¡å±è¯·å¿å¨åè°å½æ°éç´æ¥ä½¿ç¨var map = new qq.maps.Map() å¦åæå¯è½å¯¼è´é¡µé¢å建åºå¤ä¸ªå°å¾å¯¹è±¡ã
å®ä½æåæ¶è¿åçç»æ
注æï¼è¥å®ä½å¤±è´¥ï¼åæ ·ä¼è§¦åmessageäºä»¶ï¼ä½è¿åçevent.data为nullï¼
å®ä½å¤±è´¥æ¶ï¼è¿åæ¶é´æ¯ä¸ç¡®å®çï¼å»ºè®®ä¸å¡è°ç¨æ¹å¯ä»¥æ ¹æ®èªå·±çä¸å¡åºæ¯è®¾ç½®è¶
æ¶é»è¾ï¼ä¾å¦ï¼å¯ä»¥è®¾ç½®6sè¶
æ¶å认为å®ä½å¤±è´¥ï¼ã
主å¨ä¸å端å®ä½ç»ä»¶éä¿¡ï¼å¯éï¼
卿äºåºæ¯ä¸ï¼ä¸å¡è°ç¨æ¹å¯è½éè¦ä¸»å¨è·å®ä½ç»ä»¶éä¿¡ï¼æ¯å¦å次è·åç¨æ·çä½ç½®ä¿¡æ¯ï¼æè
å¨å®ä½å¤±è´¥çæ
åµä¸è·åç²ç³çIPå®ä½ç»æï¼å¯ä»¥éè¿html5 postMessageçæ¹å¼ä¸»å¨ä¸å®ä½ç»ä»¶åèµ·éä¿¡ï¼å端å®ä½ç»ä»¶æ¯æçéä¿¡äºä»¶æï¼
1. getLocation: è·åå½åæå¨å°çä½ç½®ï¼è°ç¨ä¸æ¬¡å³éæ°å®ä½ä¸æ¬¡ï¼å®ä½æ°æ®æ¯è¾ç²¾ç¡®ã
2. getLocation.robust: ç«å³è·åå½åæå¨å°çä½ç½®ï¼éç¨äºé精确å®ä½åºæ¯ï¼æ¯IPå®ä½ï¼åå¸çº§å«ã
3. watchPosition: çå¬ä½ç½®ä¿¡æ¯çæ¹åï¼ç±»ä¼¼HTML5 GeolocationçwatchPosition
4. clearWatch: æ¸
é¤çå¬ï¼ç±»ä¼¼HTML5 GeolocationçclearWatch
å¨ä¸åçç½ç»ç¯å¢ä¸ï¼è·åå°å®ä½çæ¶é´æ¯ä¸ç¡®å®çã
妿è¦è·å¾ä¸ä¸ªç²¾ç¡®å®ä½ï¼éç¨getLocation
妿è¦ç«å³è·å¾ä¸ä¸ªç²ç³å®ä½ï¼éç¨getLocation.robust
宿´ç¤ºä¾
å¨è¯¥ç¤ºä¾ä¸ï¼é¡µé¢å
åµäºä¸¤ä¸ªiframe, ä¸ä¸ªæ¯å端å®ä½ç»ä»¶ï¼å¦ä¸ä¸ªæ¯ä½ç½®å±ç¤ºç»ä»¶ãå¨å端å®ä½ç»ä»¶å®ä½æååï¼ä¼å°ç»æpostç»ç¶é¡µé¢ï¼ç¶é¡µé¢è·åå°ç»çº¬åº¦åï¼åå¨ææ¼æ¥ä½ç½®å±ç¤ºç»ä»¶çURL,å¨å°å¾ä¸æ æ³¨ç¨æ·çå½åä½ç½®ã
è°ç¨æ¹å¼ä¸
å¼å
¥å°è£
好çJSæä»¶ï¼éè¿è°ç¨js apiçæ¥å£è·åå®ä½ä¿¡æ¯ã对æ¯å两ç§iframeçè·åæ¹å¼ï¼ä¼åäºå®ä½æ¶é¿çä½éªã
代ç å°å jså¼å
¥å°åï¼https://apis.map.qq.com/tools/geolocation/min?key=your key&referer=myapp
åèç±»ï¼qq.maps.Geolocation æé 彿° 说æ qq.maps.Geolocation(key, referer) åæ°ï¼ key ï¼ å¿
å¡«ï¼å¼åå¯é¥(key)ï¼ç³è¯·å°å https://lbs.qq.com/dev/console/key/manage refererï¼ å¿
å¡«ï¼è°ç¨æ¥æºï¼ä¸è¬ä¸ºæ¨çåºç¨åç§°ï¼ä¸ºäºä¿é对æ¨çæå¡ï¼è¯·å¡å¿
å¡«åï¼ä¾å¦ï¼ referer=mapqq æ¹æ³ è¿åå¼ è¯´æ getLocation(sucCallback, errCallback, [options: {timeout: number, failTipFlag: boolean}]) è·åå½åæå¨å°çä½ç½®ï¼è°ç¨ä¸æ¬¡å³éæ°å®ä½ä¸æ¬¡ï¼å®ä½æ°æ®æ¯è¾ç²¾ç¡®ã
sucCallback为å®ä½æååè°å½æ°ï¼å¿
å¡«ï¼
errCallback为å®ä½å¤±è´¥åè°å½æ°ï¼éå¡«ï¼å¦æä¸å¡«ï¼è¯·è®¾ä¸ºnullï¼
options为å®ä½é项ï¼éå¡«ï¼å¯ä»¥éè¿timeoutåæ°è®¾ç½®å®ä½çè¶
æ¶æ¶é´ï¼é»è®¤å¼ä¸º10s;
failTipFlag: æ¯å¦å¨å®ä½å¤±è´¥æ¶ç»åºæç¤ºå¼å¯¼ç¨æ·æå¼ææææå¼å®ä½å¼å
³ãï¼å³å°æ¯æï¼ getIpLocation(sucCallback, [errCallback]) ç«å³è·åå½åæå¨å°çä½ç½®ï¼éç¨äºé精确å®ä½åºæ¯ï¼æ¯IPå®ä½ï¼åå¸çº§å«ã
sucCallback为å®ä½æååè°å½æ°ï¼å¿
å¡«ï¼
errCallback为å®ä½å¤±è´¥åè°å½æ°ï¼éå¡«ã watchPosition(sucCallback) çå¬ä½ç½®ä¿¡æ¯çæ¹åï¼ç±»ä¼¼HTML5 GeolocationçwatchPositionã
sucCallback为å®ä½æååè°å½æ°ï¼å¿
å¡«ã clearWatch() æ¸
é¤çå¬ï¼ç±»ä¼¼HTML5 GeolocationçclearWatchã 宿´ç¤ºä¾ é¢è§
RetroSearch is an open source project built by @garambo
| Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.3