Comments (3)
@phegman thank you for the the answer. It helped changing to map-init. I still think that it is odd that the load has that behavior.
Regarding the id that makes sense, but I just thought that mapbox would be transformed into the #map container. Why element with the id created is not created by the ?
Thanks!
from vue-mapbox-gl.
The div with an ID of map is created by the Mapbox component so there is no need to wrap the component in a div with an ID of map.
from vue-mapbox-gl.
Hi João,
That is very weird, I will have to dig deeper into this to find out why this would happen. I played around with it and discovered if you use the @map-init
event to set the map
object then the bug is no longer there.
I also noticed you are wrapping the mapbox component in a div with an ID of map
. The mapbox component by default gets rendered with an ID of map
so this would cause a duplicate ID. You can pass a custom container ID to the mapbox component through the options prop.
See below example for bug fix and passing custom container
<template>
<div id="map" class="map">
<mapbox
access-token=""
:map-options="{
style: 'mapbox://styles/mapbox/streets-v9',
center: [-96, 37.8],
zoom: 9,
container: 'map2'
}"
@map-init="mapInitialized"
>
</mapbox>
<button @click="flyTo">Center</button>
</div>
</template>
<script>
import Mapbox from 'mapbox-gl-vue';
export default {
data() {
return {
map: {}
}
},
components: { Mapbox },
methods: {
mapInitialized(map) {
this.map = map
},
flyTo () {
this.map.flyTo({
center: [4.498558399999999, 51.9220879]
})
}
}
}
</script>
Hope that is helpful!
from vue-mapbox-gl.
Related Issues (20)
- Custom Interactive Controls HOT 1
- Mapbox with Quasar; export 'default' (imported as 't') was not found in 'vue'
- cannot get to work with nuxt HOT 1
- v-if not followed while tiles are loading HOT 1
- Trying to use latest 2.0.3 with Mapbox.js error HOT 2
- printing the map issue
- "For larger projects VueMapbox may be a better fit." Don't say that HOT 2
- importing Marker doesn't work HOT 1
- Is there a way to trigger() geolocation programmatically? HOT 1
- Cannot find module 'vue'
- Adding markers stop the map from drawing HOT 4
- Making width 100% so it fills space in responsive screen size HOT 1
- Access to mapbox-gl-draw events
- Safari: [Vue warn]: Error in mounted hook: "ReferenceError: Can't find variable: mapboxgl"
- how to add a geocoder?
- Error: when testing with `jest`
- How to add markers to the map
- mouseenter and mouseleave for fills HOT 1
- error Popup example not fount HOT 1
- How to add custom icons with Markers?
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from vue-mapbox-gl.