欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

uniapp使用webview調(diào)用谷歌地圖的完整過程(小程序+app端)

 更新時間:2025年07月09日 10:22:08   作者:蔡一一  
最近在做uni-app的項目,由于是海外市場,所以在APP中需要使用到谷歌地圖,這篇文章主要介紹了uniapp使用webview調(diào)用谷歌地圖(小程序+app端)的相關(guān)資料,需要的朋友可以參考下

前言

適用小程序和app端;具體功能可以搜索地址,選中地址返回。

一.前期準備

1.谷歌地圖需要科學 上網(wǎng),否則無法加載。需要的軟件自己備好,后續(xù)在模擬器測試也可以用到。

2.申請谷歌地圖密鑰

平臺地址:https://developers.google.cn/maps/gmp-get-started

選擇Maps JavaScript API

如需使用搜索地址則需開啟,啟用Places API(原先舊的api,在H5使用可能出現(xiàn)跨域問題,如后端可以解決,可直接使用這個)和Places API(New)(新的api,返回報錯403)

二.相關(guān)代碼

1.uniapp代碼

點擊選擇地址頁面

跳轉(zhuǎn)地圖顯示頁面

這里我看別人可以使用放置在本項目的html文件(例如/hybrid/html/map.html),但是我引用本地的沒效果,后面就替換成線上的了。

但是這里你可以在本地運行html文件,然后使用本地ip調(diào)用可以做調(diào)試用

注意:
1.這里的@message="postMessageFun"方法是接收來自html頁面的返回值。
2.如果需要在模擬器校驗app效果,需要換成線上地址。

2.html文件

這里引入了vue,有些是vue寫法的

<!DOCTYPE html>
<html style="width: 100vw;height: 100vh;">
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
		<!-- 引入vue -->
		<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>

		<!-- 引入樣式element組件 -->
		<link rel="stylesheet"  rel="external nofollow" >
		<!-- 引入組件庫 -->
		<script src="https://unpkg.com/element-ui/lib/index.js"></script>

		<!-- 引入less處理器 -->
		<link rel="stylesheet/less" type="text/css" href="./css/map.less" rel="external nofollow"  />
		<script src="https://cdn.jsdelivr.net/npm/less"></script>

		<!-- 引入axios -->
		<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
	</head>
	<body>
		<div id="app" class="popup">
			<div class="tools">
				<i class="el-icon-circle-close close-icon" @click="close"></i>
				<el-button type="primary" class="tools-btn" @click="confirm">Confirm</el-button>
			</div>
			<div class="map">
				<div id="googleMap"></div>
			</div>
			<div class="box">
				<div class="label">
					<i class="el-icon-search search-icon"></i>
					<input v-model="searchAddress" type="text" placeholder="search place"
						placeholder-style="color:#b8b8b8;" />
				</div>
				<div class="lists">
					<div class="list" v-for="(item, index) in list">
						<div class="radio-box">
							<span class="radio-name">{{ item.name }}</span>
							<span class="radio-text">{{ item.formatted_address }}</span>
						</div>
						<el-radio v-model="current" :label="index.toString()" @input="radioChange"> </el-radio>
					</div>
				</div>
			</div>
		</div>
	</body>

	<!-- 微信 JS-SDK  -->
	<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"></script>
	<!-- uni 的 SDK -->
	<script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script>

	<script>
		// 初始化地圖
		var map;

		function initMap() {
			//頁面?zhèn)鬟^來的參數(shù)arr
			var mapPointResult = GetUrlParam('arr') ? JSON.parse(decodeURIComponent(GetUrlParam('arr'))) : [{
				lng: 103.53028,
				lat: 10.62592
			}];

			var centerPoint = {
				lat: mapPointResult[0].lat,
				lng: mapPointResult[0].lng,
			};

			map = new google.maps.Map(document.getElementById('googleMap'), {
				center: centerPoint,
				zoom: 16
			});

			var marker = new google.maps.Marker({
				position: centerPoint,
				map: map,
				icon: {
					url: 'https://now.guua.com/attachs/default/location_shop.png',
					scaledSize: new google.maps.Size(30, 30),
					origin: new google.maps.Point(0, 0),
					anchor: new google.maps.Point(0, 0)
				}
			});
		}

		// 處理URL參數(shù)
		function GetUrlParam(paraName) {
			var url = window.location.href;
			var arrObj = url.split("?");
			if (arrObj.length > 1) {
				var arrPara = arrObj[1].split("&");
				var arr;
				for (var i = 0; i < arrPara.length; i++) {
					arr = arrPara[i].split("=");
					if (arr != null && arr[0] == paraName) {
						return arr[1];
					}
				}
				return "";
			} else {
				return "";
			}
		}

		// 定位(這里如果需要搜索選中地址后定位到選中位置,可以調(diào)用這個方法)
		// function searchAddress() {
		// 	var address = '北京';
		// 	var geocoder = new google.maps.Geocoder();
		// 	geocoder.geocode({
		// 		'address': address
		// 	}, function(results, status) {
		// 		if (status === 'OK') {
		// 			var latlng = results[0].geometry.location;
		// 			var map = new google.maps.Map(document.getElementById('googleMap'), {
		// 				zoom: 15,
		// 				center: latlng
		// 			});
		// 			var marker = new google.maps.Marker({
		// 				position: latlng,
		// 				map: map,
		// 				title: 'Address Location'
		// 			});
		// 		} else {
		// 			alert('Geocode was not successful for the following reason: ' + status);
		// 		}
		// 	});
		// }
	</script>

	<!-- 引入谷歌地圖 -->
	<script src="https://maps.googleapis.com/maps/api/js?key=你的秘鑰&callback=initMap"
		async defer></script>

	<script>
		new Vue({
			el: '#app',
			data: {
				googleKey: '你的秘鑰',
				searchAddress: '',
				current: -1,
				list: [],
				curPlace: false
			},

			watch: {
				searchAddress: {
					handler(newV) {
						if (newV) {
							this.searchFindAddress();
						} else {
							this.list = [];
						}
					},
					deep: true
				}
			},

			methods: {
				// 關(guān)閉地圖
				close() {
					uni.navigateBack({
						delta: 1
					});
				},

				// 選中地址
				confirm() {
					let thar = this;
					if (this.curPlace) {
						let curPlace = JSON.parse(this.curPlace);
						let latlng = {
							lat: curPlace.geometry.location.lat,
							lng: curPlace.geometry.location.lng
						};

						let url =
							`https://maps.googleapis.com/maps/api/geocode/json?key=${this.googleKey}&latlng=${latlng.lat},${latlng.lng}&language=en`;

						axios.get(url).then(res => {
							console.log('確定選中地址回調(diào)', res)
							if (res.status == 200) {
								let resData = res.data;
								let compound_code = resData.plus_code.compound_code;
								compound_code = compound_code.split(' ');
								let obj = {
									compound_code: compound_code[1],
									latlng: latlng,
									// name: curPlace.name
									name: curPlace.formatted_address
								};
								
								//選中返回uniapp的值
								uni.postMessage({
									data: obj
								});
								
								thar.close();
							}
						}).catch(err => {
							console.log(err)
						})
					} else {
						alert('請先選中地址?。?!')
					}
				},

				//搜索
				searchFindAddress() {
					let thar = this;
					this.current = -1;
					this.list = [];
					// 原有的接口出現(xiàn)跨域問題(新的api需要注冊才可以用)
					// let url =
					// 	`https://maps.googleapis.com/maps/api/place/textsearch/json?key=${this.googleKey}&query=${encodeURIComponent(this.searchAddress)}&language=en`;

					// 可以調(diào)用,但是返回的信息不完整(這里沒有返回具體的地址)
					let url =
						`https://maps.googleapis.com/maps/api/geocode/json?address=${encodeURIComponent(this.searchAddress)}&key=${this.googleKey}`;

					axios.get(url)
						.then(response => {
							console.log('搜索地址', response);
							if (response.data.status === 'OK') {
								let resData = response.data.results;
								thar.list = resData;
							} else {
								thar.list = [];
							}
						})
						.catch(error => {
							// this.errorMessage = '請求失敗,請稍后再試';
							console.error('請求失敗', error);
						});
				},

				//列表選中地址
				radioChange(e) {
					this.current = e;
					this.curPlace = JSON.stringify(this.list[this.current]);
				},

			}
		})
	</script>
</html>

注意的點:

1.需要和uniapp頁面通信的話,必須引入這兩個SDK,并且需要放在body后面,而且微信SDK必須在前面。

2.谷歌搜索api問題

這里后續(xù)我讓后端給我處理了。

https://maps.googleapis.com/maps/api/place/textsearch/json?key=你的密鑰&query=搜索地址&language=en
這個是舊的api,但是在H5頁面使用會出現(xiàn)跨域問題,最好是讓后端給解決一下,直接給你一個接口。

https://places.googleapis.com/v1/places:searchText是新的api,這里調(diào)用會出現(xiàn)403報錯。這里確定配置平臺已啟用了Places API(New),不曉得是哪里不行,求知道的大佬告知。
以下為調(diào)用的代碼片段和報錯信息

let url = `https://places.googleapis.com/v1/places:searchText`;
axios.post(url, {
	textQuery: this.searchAddress,
	'X-Goog-FieldMask': '*',
	'X-Goog-Api-Key': '你的密鑰'
}).then(response => {
	console.log('搜索地址', response);
	if (response.data.status === 'OK') {
		let resData = response.data.results;
		thar.list = resData;
	} else {
		thar.list = [];
	}}).catch(error => {
		// this.errorMessage = '請求失敗,請稍后再試';
		console.error('請求失敗', error);
	});

三.效果圖

網(wǎng)頁端

小程序

app

四.其他

這里如果想在模擬器測試,需要在模擬器安裝跨域工具(和在真機安裝配置一樣)。

這里配置自己搜索下進行配置就好。

開啟后,就能進去app校驗地圖效果了。

到此這篇關(guān)于uniapp使用webview調(diào)用谷歌地圖(小程序+app端)的文章就介紹到這了,更多相關(guān)uniapp webview調(diào)用谷歌地圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js事件流、事件委托與事件階段實例詳解

    js事件流、事件委托與事件階段實例詳解

    事件委托應(yīng)用在很多開發(fā)場景之中,但是很多同學對委托的原理、特別是對JS原生實現(xiàn)委托不太了解,下面這篇文章主要給大家介紹了關(guān)于js事件流、事件委托與事件階段的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • js 字符串轉(zhuǎn)換成數(shù)字的三種方法

    js 字符串轉(zhuǎn)換成數(shù)字的三種方法

    在js讀取文本框或者其它表單數(shù)據(jù)的時候獲得的值是字符串類型的,例如兩個文本框a和b,如果獲得a的value值為11,b的value值為9 ,那么a.value要小于b.value,因為他們都是字符串形式的.在網(wǎng)上找了一下js字符串轉(zhuǎn)數(shù)字的文章,這個比較全
    2013-03-03
  • JavaScript實現(xiàn)俄羅斯方塊游戲過程分析及源碼分享

    JavaScript實現(xiàn)俄羅斯方塊游戲過程分析及源碼分享

    這篇文章主要介紹了JavaScript實現(xiàn)俄羅斯方塊游戲過程分析及源碼分享,本文分解了游戲規(guī)則、實現(xiàn)過程、難點分析及實現(xiàn)源碼,需要的朋友可以參考下
    2015-03-03
  • webpack4之SplitChunksPlugin使用指南

    webpack4之SplitChunksPlugin使用指南

    這篇文章主要介紹了webpack4之SplitChunksPlugin使用指南,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • ckeditor一鍵排版功能實現(xiàn)方法分析

    ckeditor一鍵排版功能實現(xiàn)方法分析

    這篇文章主要介紹了ckeditor一鍵排版功能實現(xiàn)方法,結(jié)合實例形式分析了ckeditor一鍵排版相關(guān)擴展插件定義、配置與使用方法,需要的朋友可以參考下
    2020-02-02
  • LayUI數(shù)據(jù)接口返回實體封裝的例子

    LayUI數(shù)據(jù)接口返回實體封裝的例子

    今天小編就為大家分享一篇LayUI數(shù)據(jù)接口返回實體封裝的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • Javascript Web Slider 焦點圖示例源碼

    Javascript Web Slider 焦點圖示例源碼

    Slider 焦點圖會在很多的網(wǎng)站上見到,在本文為大家詳細介紹下具體的實現(xiàn)過程,下面的源碼大家可以運行下
    2013-10-10
  • 如何利用Three.js實現(xiàn)web端顯示點云數(shù)據(jù)

    如何利用Three.js實現(xiàn)web端顯示點云數(shù)據(jù)

    這篇文章主要給大家介紹了關(guān)于如何利用Three.js實現(xiàn)web端顯示點云數(shù)據(jù)的相關(guān)資料,最近在項目中遇到需求,需要在web端顯示點云數(shù)據(jù),將我的實現(xiàn)步驟介紹在這里供大家參考,需要的朋友可以參考下
    2023-11-11
  • JavaScript 判斷數(shù)據(jù)類型的4種方法

    JavaScript 判斷數(shù)據(jù)類型的4種方法

    這篇文章主要介紹了JavaScript 判斷數(shù)據(jù)類型的4種方法,幫助大家更好的理解和學習JavaScript,感興趣的朋友可以了解下
    2020-09-09
  • javascript中先加加和后加加區(qū)別 ++a和a++區(qū)別解析

    javascript中先加加和后加加區(qū)別 ++a和a++區(qū)別解析

    從學習 javascript 開始,就對 先加加 和 后加加 模糊不清,時至今日,再來學習一下,這篇文章主要介紹了javascript中先加加和后加加區(qū)別++a和a++區(qū)別解析,需要的朋友可以參考下
    2023-09-09

最新評論