我想知道是否有人可以借我一把。为什么Svg路径出现在控制台中而不是屏幕上?
我试图呈现从以下topoJSON我已经皈依地图新加坡。
下面是我的代码:
<style>
path {
/*fill: #ccc;*/
stroke: rgba(12, 12, 12, 0.96);
stroke-linejoin: round;
}
</style>
<svg width="900" height="600"></svg>
<script src="https://d3js.org/d3.v4.min.js"></script>
<script src="https://d3js.org/topojson.v2.min.js"></script>
<script>
var svg = d3.select("svg"),
width = +svg.attr("width"),
height = +svg.attr("height");
// var projection = d3.geoAlbers();
var projection = d3.geoMercator()
.center([0, 5 ])
.scale(900)
.rotate([-180,0]);
var path = d3.geoPath(projection);
d3.queue()
.defer(d3.json, "data/sgtopo.json")
.await(ready);
function ready(error, sg){
if(error) throw error;
var topofeature = topojson.feature(sg, sg.objects["sg-"]);
svg.append("g")
.selectAll("path")
.data(topofeature.features)
.enter()
.append("path")
.attr("d", path);
}
</script>
</html>
虽然我看到控制台上生成的路径:页面保持空白。 希望有任何帮助,谢谢!
我不能再生的问题(图未呈现,在所有),你可以在这里或在创造的jsfiddle一个片段,用于JSON文件数据,你可以使用一些虚拟对象。 –
嘿感谢您花时间回复,感谢您。这里是jsfiddle:https://jsfiddle.net/Lzx5rnzy/ – cookiedookie