var vectorSource = new ol.source.Vector({
features: features
});
var vectorLayer = new ol.layer.Vector({
source: vectorSource,
style: function (feature) {
feature.setStyle(typeitems(feature));
console.log("apple");
}
});

这是我的代码。 为什么不能运行这行console.log(" apple");在ol.layer.Vector?
答案 0 :(得分:0)
style
属性会将ol.Style | ol.Style[] | ol.StyleFunction
应用于所有没有自己风格的功能。
如果您发布完整的样本,我们可能会帮助您更好。但是,我假设样式函数签名类似于function typeitems(feature: ol.Feature): ol.Style
。在这种情况下,您可以像这样重写代码:
var vectorLayer = new ol.layer.Vector({
source: vectorSource,
style: function (feature) {
return typeitems(feature);
}
});
[...]
function typeitems(feature: ol.Feature): ol.Style {
return new ol.Style({
stroke: new ol.Style.Stroke({ color: 'red', width: 5})
});
}
在这里,typeitems()
有点毫无意义,因为它总会创建相同的红色笔触样式,但是你明白了如何解决问题。如果您需要更具体的帮助,请发布比这种最小变量声明更多的相关代码。