React-Leaflet отображает локальные плитки в среде разработки - PullRequest
0 голосов
/ 16 января 2019

Мне нужна помощь для решения возникшей проблемы с использованием Webpack с React-листовкой, когда я хочу загрузить плитки своей карты, я получаю это сообщение об ошибке для каждой плитки

GET http://localhost:9080/home/drigtime/Documents/electron-webpack-quick-start/static/tiles/amakna/3/11/6.jpg 404 (Not Found)

Вот мой код компонента:

class MapComponent extends Component {
  state = {
    crs: L.CRS.Simple,
    hightLight: [],
    lat: -250,
    lng: 425,
    markers: [],
    maxZoom: 4,
    minZoom: 0,
    zoom: 3
  };
  render() {
    const { lat, lng, zoom, crs, maxZoom, minZoom } = this.state;
    const position = [lat, lng];

    return (
      <Map
        center={position}
        zoom={zoom}
        maxZoom={maxZoom}
        minZoom={minZoom}
        crs={crs}
      >
        <MapCoord />
        <MapArea />
        <HightLight />
        <TileLayer url={join(__static, "./tiles/amakna/{z}/{x}/{y}.jpg")} />
      </Map>
    );
  }
}

Я что-то не так делаю? Как я могу загрузить свои фрагменты карты в среде разработки?

Вот репо моего проекта https://github.com/Drigtime/owltouch/tree/beta

1 Ответ

0 голосов
/ 16 января 2019

Хорошо, я исправил проблему, добавив:

include : path.join(__dirname, "static")

в файл конфигурации веб-пакета для модуля "url-loader".

{ test: /\.(png|jpg)$/, loader: "url-loader", include: [path.join(__dirname, 'static')] }

После этого я получил новое сообщение об ошибке:

Not allowed to load local resource: file:///home/drigtime/Document/electron-webpack-quick-start/static/tiles/amakna/3/12/6.jpg"

Итак, я отключил веб-безопасность

const window = new BrowserWindow({
  webPreferences: {
    webSecurity: false
  }
})

И это сработало! Моя карта окончательно рендерится! :)

...