Qgis2web
QGIS plugin to export your project to an OpenLayers or Leaflet webmap. No server-side software required.
Install / Use
/learn @qgis2web/Qgis2webREADME
![]()
QGIS plugin to export your project to an OpenLayers or Leaflet webmap.</br> It replicates as many aspects of the project as it can, including layers, extent and styles (including categorized and graduated).</br> No server-side software required.
<h2>Installation</h2> <ul> <li>In QGIS, select <code>Plugins > Manage and Install Plugins...</code></li> <li>Find <code>qgis2web</code></li> </ul> <p>or:</p> <ul> <li><a href="https://github.com/qgis2web/qgis2web/archive/master.zip" target="_blank">Download</a> master repository from github</li> <li>In QGIS, open <code>Plugins > Manage and Install Plugins... > Install from ZIP</code></li> </ul> <h2>Usage</h2> <p>Prepare your QGIS map with simple symbologies. You can improve your webmap like this: </p> <ul> <li>Set your project title, abstract, background and highlight colours in <code>Project > Properties... > General/Metadata</code></li> <li>Give your layers human-friendly names in <code>Layers Panel</code></li> <li>Give your layer columns human friendly names via <code>Layer > Properties > Attributes Form > Fields > Alias</code></li> <li>Hide fields you don't want to appear in your popups by changing their Widget Type to "Hidden"</li> <li>Show media in your popups by changing their Widget Type to "Attachment" (your fields must contain image's path)</li> <li>Style your layers as explained in [WIKI](https://qgis2web.github.io/qgis2web/), and set their scale-dependent visibility, if required</li> </ul> <p>Run qgis2web from the Web menu, or via its icon in Web toolbar</p> <p>The panes lets you set options to export your map. All options are written to your QGIS project, so save your project if you want to keep these settings. </p> <h2>Documentation</h2>Read documentation on the WIKI
<h2>Awards</h2>qgis2web is among the winners of the OSGeo:UK 2024 competition via GoFundGeo
</br>
Please consider a small donation; even a modest "virtual coffee" can help support our commitment to providing quality software.
<img src="https://github.com/tomchadwin/qgis2web/assets/89784373/3bf8e193-e65e-4dc6-a189-a9e669f98b1e"> </br><b>🎁 As a token of our gratitude, donors will receive as a gift qgis2o.gis (a plugin enhancing OpenLayers export of qgis2web).🎁</b>
Thank you for your support! </br>Happy mapping!🗺️
<h2>Credits</h2> qgis2web's author is Tom Chadwin (@tomchadwin), in charge as official developer from April 2015 to November 2023, from this date Andrea Ordonselli (@andreaordonselli) took over. <p>The list of all other contributing developers is available at this link https://github.com/qgis2web/qgis2web/graphs/contributors <p>For qgis2web enthusiasts we recommend reading this splendid article written by Tom which describes the birth and growth of qgis2web: https://tom.chadw.in/wrote/qgis2webTheStorySoFar <p>In short words: <p>qgis2web is fundamentally a merge of Victor Olaya's qgis-ol3 and Riccardo Klinger's qgis2leaf. It would not exist without their work. Thank you, gentlemen. Thanks are also very much due to Paolo Cavallini, who suggested and supported the merge.</p> <ul> <li>@volaya</li> <li>@riccardoklinger</li> <li>@pcav</li> </ul> <p>Obviously, qgis2web could not exist without the following monumental software:</p> <ul> <li>QGIS</li> <li>OpenLayers</li> <li>Leaflet</li> </ul> <p>Thanks are also due for major code contributions to:</p> <ul> <li>@akbargumbira</li> <li>@lucacasagrande</li> <li>@walkermatt</li> <li>@boesiii</li> <li>@ThomasG77</li> <li>@NathanW2</li> <li>@nyalldawson (FTP export for Faunalia/ENEL)</li> <li>@perliedman</li> <li>@olakov</li> </ul> <p>In addition, the following libraries have been used:</p> <ul> <li><a href="https://github.com/walkermatt/ol-layerswitcher">ol-layerswitcher</a>, by @walkermatt</li> <li><a href="https://github.com/gregjacobs/Autolinker.js">Autolinker.js</a>, by @gregjacobs</li> <li><a href="https://gist.github.com/paulirish/1579671">requestAnimationFrame polyfill</a>, by @paulirish</li> <li>Function.prototype.bind polyfill, by @mozilla</li> <li><a href="https://github.com/Leaflet/Leaflet.label">Leaflet.label</a>, by @jacobtoye</li> <li><a href="https://github.com/domoritz/leaflet-locatecontrol">Leaflet.Locate</a>, by @domoritz</li> <li><a href="https://github.com/Leaflet/Leaflet.markercluster">Leaflet.markercluster</a>, by @danzel</li> <li><a href="https://github.com/ljagis/leaflet-measure">leaflet-measure</a>, by @ljagis</li> <li><a href="https://github.com/mlevans/leaflet-hash">leaflet-hash</a>, by @mlevans</li> <li><a href="https://github.com/proj4js/proj4js">proj4js</a>, by @madair, @calvinmetcalf, @ahocevar and others</li> <li><a href="https://github.com/kartena/Proj4Leaflet">Proj4Leaflet</a>, by @kartena</li> <li><a href="https://github.com/stefanocudini/leaflet-search">leaflet-search</a>, by @stefanocudini</li> <li><a href="https://github.com/andreaordonselli/ol-search-layer">ol-search-layer</a>, by @andreaordonselli</li> <li><a href="https://github.com/mourner/simpleheat">simpleheat</a>, by @mourner</li> <li><a href="https://github.com/perliedman/leaflet-multi-style">leaflet-multi-style</a>, by @perliedman</li> <li><a href="https://github.com/rowanwins/Leaflet.SvgShapeMarkers">Leaflet.SvgShapeMarkers</a>, by @rowanwins</li> <li><a href="https://github.com/mourner/rbush">rbush</a>, by @mourner</li> <li><a href="https://github.com/Geovation/labelgun">Labelgun</a>, by @JamesMilnerUK</li> <li><a href="https://github.com/teastman/Leaflet.pattern">Leaflet.pattern</a>, by @teastman</li> <li><a href="https://github.com/Leaflet/Leaflet.VectorGrid">Leaflet.VectorGrid</a>, by @IvanSanchez</li> <li><a href="https://github.com/jjimenezshaw/Leaflet.Control.Layers.Tree">Leaflet.Control.Layers.Tree</a>, by @jjimenezshaw</li> </ul>