带有 v-for 的 vue svg 路径
vue svg path with v-for
我正在尝试将 svg 路径中的各种坐标绑定到 vue.js
中的 data()
<svg xmlns="http://www.w3.org/2000/svg" width="500" height="500">
<g>
<path v-for="n in 50" d="'M0 ' + (n*10) + ' L500 ' + (n*10)" fill="white" stroke="lightgray" />
<path v-for="n in 50" d="{'M0 ' + (n*10) + ' L500 ' + (n*10)}" fill="white" stroke="lightgray" />
</g>
</svg>
另一种方法是调用一个有效的方法,
<path v-for="n in 400" :d="gridy(n)" fill="white" stroke="lightgray" />
gridy() 方法
gridy(n) {
return "M0" + " " + (n * 10) + " L500 " + (n * 10)
},
我尝试在不调用方法的情况下执行此操作的方式不正确吗?
谢谢
您只需 bind SVG 的 d 属性,如下所示:
<path v-for="n in 50" :d="'M0 ' + (n*10) + ' L500 ' + (n*10)" fill="white" stroke="lightgray" />
工作示例:
new Vue({el: '#app'})
Vue.config.devtools = false
Vue.config.productionTip = false
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>
<main id="app">
<svg xmlns="http://www.w3.org/2000/svg" width="500" height="500">
<g>
<path v-for="n in 50" :d="'M0 ' + (n*10) + ' L500 ' + (n*10)" fill="white" stroke="lightgray" />
</g>
</svg>
</main>
我正在尝试将 svg 路径中的各种坐标绑定到 vue.js
中的 data()<svg xmlns="http://www.w3.org/2000/svg" width="500" height="500">
<g>
<path v-for="n in 50" d="'M0 ' + (n*10) + ' L500 ' + (n*10)" fill="white" stroke="lightgray" />
<path v-for="n in 50" d="{'M0 ' + (n*10) + ' L500 ' + (n*10)}" fill="white" stroke="lightgray" />
</g>
</svg>
另一种方法是调用一个有效的方法,
<path v-for="n in 400" :d="gridy(n)" fill="white" stroke="lightgray" />
gridy() 方法
gridy(n) {
return "M0" + " " + (n * 10) + " L500 " + (n * 10)
},
我尝试在不调用方法的情况下执行此操作的方式不正确吗?
谢谢
您只需 bind SVG 的 d 属性,如下所示:
<path v-for="n in 50" :d="'M0 ' + (n*10) + ' L500 ' + (n*10)" fill="white" stroke="lightgray" />
工作示例:
new Vue({el: '#app'})
Vue.config.devtools = false
Vue.config.productionTip = false
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>
<main id="app">
<svg xmlns="http://www.w3.org/2000/svg" width="500" height="500">
<g>
<path v-for="n in 50" :d="'M0 ' + (n*10) + ' L500 ' + (n*10)" fill="white" stroke="lightgray" />
</g>
</svg>
</main>