- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经成功制作了一张传单 map ,其中每个国家/地区的颜色根据我收到的 this.props.data
的输入而变化。在这个特定的 React 组件中。
它将正确显示国家/地区和初始颜色。然而,该信息每分钟都会从后端提供。如果this.props.data
更新时,国家/地区不会改变颜色 - 仅当我将鼠标悬停在特定国家/地区时;那么颜色真的会改变吗?
作为引用,我从文件(本质上是国家/地区的 JS 数据库)导入 React 类中的国家/地区,如下例所示:http://codepen.io/dagmara223/pen/jydMqy
这是我的源代码。
import React from 'react';
import L from 'leaflet';
import countries from './countries.js';
var Worldmap = React.createClass({
render: function() {
if(!this.props.data)
return <div> loading world map .. </div>;
let dataratio = this.props.data; // Props from main component
let size = Object.keys(dataratio).length; // Do we have data?
if(size > 1) { // If we do have data, ..
let dataratioToArr = Object.keys(dataratio).map(data => [ data, dataratio[data]]); // Conv. map to multidimensional array
let featuresArr = countries.features; // array of all countries in array features from countries.js
for(let i = 0; i < featuresArr.length; i++) // i = 178(no. of countries)
for(let j = 0; j < dataratioToArr.length; j++) // j = no. of countries we have with dataratio > 1 from backend
if(dataratioToArr[j][0] == featuresArr[i].id) // If ISO-3 compliant ID of country(f.e. "USA") matches, push a "data" property to countries.js
featuresArr[i].properties.data = dataratioToArr[j][1];
}
return(
<div id="leafletmap" style={{width: "100%", height: "80%", border: "2px solid black" }} />
)
},
componentDidMount : function() {
let geolocation = [];
// Retrieve geoloc coordinates
navigator.geolocation.getCurrentPosition(function(position) {
let lat = position.coords.latitude;
let lon = position.coords.longitude;
if(lat != null && lon != null) // If we can get latitude and longitude, reset geolocation and push values.
geolocation.length = 0;
geolocation.push(lat, lon);
if(!lat || !lon) // If we can't get latitude or longitude, set a default value.
geolocation = [0,0];
let map = L.map('leafletmap').setView(geolocation, 3); // ([coordinates], zoomlevel)
let info = L.control();
info.onAdd = function (map) {
this._div = L.DomUtil.create('div', 'info');
this.update();
return this._div;
};
info.update = function (props) {
this._div.innerHTML = '<h4>Data ratio</h4>' + (props ?
'<b>' + props.name + '</b><br />' + props.data + ' ratio'
: 'Hover over a country');
};
info.addTo(map);
function getColor(d) {
return d > 90 ? '#4a1486' :
d > 75 ? '#6a51a3' :
d > 50 ? '#807dba' :
d > 25 ? '#9e9ac8' :
d > 15 ? '#bcbddc' :
d > 5 ? '#dadaeb' :
d > 1 ? '#f2f0f7' :
'#D3D3D3'; // Default color of data doesn't exist or is 0.
}
function style(feature) {
return {
weight: 2,
opacity: 1,
color: 'white',
fillOpacity: 1,
fillColor: getColor(feature.properties.data)
};
}
function highlightFeature(e) {
let layer = e.target;
layer.setStyle({
weight: 5,
color: '#666',
fillOpacity: 0.7
});
if (!L.Browser.ie && !L.Browser.opera && !L.Browser.edge) {
layer.bringToFront();
}
info.update(layer.feature.properties);
}
let geojson;
function resetHighlight(e) {
geojson.resetStyle(e.target);
info.update();
}
function zoomToFeature(e) {
map.fitBounds(e.target.getBounds());
}
function onEachFeature(feature, layer) {
layer.on({
mouseover: highlightFeature,
mouseout: resetHighlight,
click: zoomToFeature
});
}
geojson = L.geoJson(countries, { // from import
style: style,
onEachFeature: onEachFeature
}).addTo(map);
let legend = L.control({position: 'bottomright'});
legend.onAdd = function (map) {
let div = L.DomUtil.create('div', 'info legend'),
grades = [1, 5, 15, 25, 50, 75, 90],
labels = [],
from, to;
for (let i = 0; i < grades.length; i++) {
from = grades[i];
to = grades[i + 1];
labels.push(
'<i style="background:' + getColor(from + 1) + '"></i> ' +
from + (to ? '–' + to : '+'));
}
div.innerHTML = labels.join('<br>');
return div;
};
legend.addTo(map);
});
}
});
export default Worldmap
我有这个componentDidMount
如getInitialState
首先;但我改为componentDidMount
因为这应该在数据更改时触发组件的重新渲染。该文档指出If you need to load data from a remote endpoint, this is a good place to instantiate the network request. Setting state in this method will trigger a re-rendering.
- 这在我的代码中并没有真正发生。也许我误解了它?
我可以理解该组件是否从未重新渲染,但如果在各个国家/地区发生鼠标悬停事件(例如,我在美国上空,并且颜色值发生变化,颜色值将更改为正确的值),这非常奇怪,但直到发生这种情况(或刷新整个网站))
最佳答案
看起来您正在将两种不同的渲染概念合并为一个。当使用 React 时,它被设计用来控制渲染过程;如果您引入另一个管理渲染的库,那么您可能会遇到问题。
React 设计为基于以下公式进行渲染:view = f(data),换句话说,您的 View 是数据的函数。在 React 中,数据通过 Props 或 State 来表达。在这种情况下,您没有使用 React 来管理 props 或状态,而是使用“传单”。您需要决定是使用 React 还是 Leaflet 来控制渲染,然后再决定。在这种情况下,最好将所有事情留给 Leaflet,因为它有自己的 API 用于渲染和管理交互。
关于javascript - 传单 w/React : Individual country color won't re-render when this. Prop 更新,仅当鼠标悬停时发生?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42903172/
我的任务其实很简单。也许我太习惯于 C++ 而看不到我的错。我有两个类(class)和一个 list 。该列表应包括由 class1 构成的所有对象,而 class1 还包括 class2 的所有对象
我有三个简单的表:users、profile 和 watched,其中包含用户的 ID 和他们观看的电影标题。 下面的脚本显示了表watched中不同用户的匹配值: $id = $_SESSION['
我正在使用具有以下简单本体的 Protege 4.3(也尝试过 5-beta): Class: Person Class: Man SubClassOf: Person Ind
在文档中,Symfony 有一种方法可以访问 customize a Individual field ,基于小部件的名称/ID。 {% form_theme form _self %} {% blo
这似乎是一个微不足道的问题。我需要知道,如果我在值(value) 99 美元的 iOS 开发者计划:公司 下注册我的公司,我现在可以在同一家公司下添加开发者。 我的问题是,这些开发者是否还需要分别拥有
有没有办法指定 matplotlib 表中各个列的宽度? 我表中的第一列仅包含 2-3 位 ID,我希望此列比其他列小,但我似乎无法让它工作。 假设我有一张这样的表: import matplotli
我有一个应用程序,我可以在流程的一部分中以 JSON 格式将消息写入 Azure 服务总线队列。我有一个下游进程,我希望将该消息从队列中弹出,将 json 转换为对象,然后处理该对象。 我将消息推送到
我有一个程序,它告诉用户输入三个int并将每个整数转换为字符串。 即 1 = 1 ; ...等等。这里的问题是为每个用户输入定义int。我怎样才能只用一个输入来获取它并循环它以获取另一个输入,考虑到单
我已经在 unity 中工作了一段时间,并且已经通过关注 this 获得了基本的多人游戏设置。教程。但是,我想添加更多东西,其中之一是跟踪每个玩家的相机。我已经查过了,甚至找到了该教程创建者的评论。所
我有一个单词列表,只想保留名词。 这不是 Extracting all Nouns from a text file using nltk 的重复项 在链接的问题中处理一段文本。接受的答案提出了一个标
一个愚蠢的问题:假设我有一个存储在 View 状态中的对象。我将其标记为可序列化。我还在我的 WCF 服务中重复使用相同的对象。但是 Web 服务序列化并公开了一些不需要/不安全地显示给服务客户端的内
我正在编写 Rspec 测试,但它们失败了,因为 Mysql 无法识别字段列表中的 individual 列。 当我查看内部时,individual 列确实存在于数据库中。 schema.rb 将其列
将一些自定义样式应用到不符合主题默认样式的单个小部件元素的最方便的方法是什么。我仍然对装饰器的用法感到困惑。如何应用多个装饰器,例如。用于小部件元素的边框属性和背景。 我尝试过使用自定义装饰器,例如。
我正在尝试通过 Eclipse 访问本体。我使用猫头鹰 api。我在 Protegé 中创建我的本体,但是我想通过代码创建和分类新的个体。这怎么可能?我用谷歌搜索了所有内容,但找不到任何有用的信息。
我想将可配置产品的所有子项设置为“单独不可见”,并且还为可配置产品的子项激活网站下的复选框。 有办法吗? 最佳答案 如果您没有 MySQL 访问权限,我相信这也可以: $sites=Mage::app
使用 maptplotlib,我使用 scatter 方法绘制了一些点(参见下面的代码)。我想单独标记每个点。 此代码将用 labels 数组标记每个点,但我希望我的第一个点用 labels[0] 标
我目前正在用 C 语言编写嵌入式应用程序,其中性能至关重要。 目前,我正在分配大量空内存,如下所示:calloc(1, num_bytes) - 然而,我只是将 num_bytes 计算为多个项目和代
我有一个接受多个参数的程序,例如 breakfast.py --customer=vikings eggs sausage bacon 可以从特定选项列表中指定“鸡蛋”、“香肠”和“培根”。 现在我希
我想听取表单的值更改,但不是针对整个表单,而是仅针对已更改的表单控件。 例如,如果我的表单看起来像这样。 this.form = this._fb.group({ firstName: [''],
在 W3 OWL 规范中,个体的属性分为两组:数据类型属性和对象属性。定义了对象属性(正如我发现的一篇文章所说的那样): "Object properties (owl:ObjectProperty)
我是一名优秀的程序员,十分优秀!