gpt4 book ai didi

javascript - Vue.js 和 masonry - 本地和远程的不同行为

转载 作者:行者123 更新时间:2023-11-30 15:38:13 26 4
gpt4 key购买 nike

我正在创建一个带有图像 masonry 的页面,尽管这些图像将被异步获取。此外,您可以过滤图像,因此每次更改后都应重新渲染。

我的 vue 组件:

<template>
<div>
<div class="fixed-panel">
<h4 class="site-name">Smart Math Puzzles</h4>
<a class="btn btn-sm btn-success" @click="difficulty = 1">easy</a>
<a class="btn btn-sm btn-info" @click="difficulty = 2">medium</a>
<a class="btn btn-sm btn-warning" @click="difficulty = 3">hard</a>
<a class="btn btn-sm btn-primary" @click="difficulty = 0">all</a>
</div>
<div id="grid">
<div class="grid-sizer"></div>
<div class="grid-item" v-for="puzzle in puzzles" @click="openModal(puzzle)">
<img :src="puzzle.imageAddress">
<div class="overlay">
<span class="title">{{ puzzle.name }}</span>
</div>
</div>
</div>

<puzzle-modal></puzzle-modal>
</div>
</template>
<script>
import Masonry from 'masonry-layout';
import ImagesLoaded from 'imagesloaded';
import PuzzleModal from './PuzzleModal.vue';
export default {
data: function() {
return {
difficulty: 0,
allPuzzles: []
}
},

computed: {
puzzles: function() {
return this.filterPuzzlesByDifficulty(this.difficulty);
}
},

watch: {
puzzles: function() {
this.createGrid();
}
},

mounted: function() {
this.fetchPuzzlesData();
},

methods: {
fetchPuzzlesData: function() {
this.$http.get('api/puzzles')
.then((response) => {
this.allPuzzles = response.data;
});
},

openModal: function(puzzle) {
this.$eventHub.$emit('openModal', puzzle);
},

filterPuzzlesByDifficulty: function(diff) {
if (diff === 0)
return this.allPuzzles;
else
return this.allPuzzles.filter((puzzle) => puzzle.difficulty === diff);
},

imagesLoaded: function() {
const grid = document.querySelector('#grid');
return new ImagesLoaded(grid, () => {
setTimeout(() => {
this.masonry();
}, 100);
});
},

masonry: function() {
const grid = document.querySelector('#grid');
return new Masonry(grid, {
percentPosition: true,
itemSelector: '.grid-item',
columnWidth: '.grid-sizer',
});
},

createGrid: function() {
if (!this.allPuzzles.length > 0)
return;

this.imagesLoaded();
}
},

components: {
'puzzle-modal': PuzzleModal,
}
}
</script>

问题是:在本地服务器上(图像几乎是立即加载的)一切正常,我的意思是:您可以使用计算值过滤图像,并使用 masonry 渲染它们。

但是在远程服务器上这开始中断。 Masonry 不等待图像加载 而且,这对我来说很奇怪,计算值不起作用。如果我想显示全部,然后单击“全部”过滤器就可以了,所有元素都从 allPuzzles 添加到拼图。但是任何其他过滤器(简单、中等、困难)都会导致计算出的谜题根本没有任何元素。

最佳答案

好的。我已经解决了将 this.imagesLoaded() 包装在 this.$nextTick 中的问题,因此 createGrid 方法如下所示:

this.$nextTick(() => this.imagesLoaded());

此外,过滤问题是由不同的数据类型引起的。我不知道为什么在本地开发中它被忽略了。

关于javascript - Vue.js 和 masonry - 本地和远程的不同行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41208019/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com