问题描述
出于学习目的,我正在开发一个小型的svelte应用程序(对svelte来说是新手)。
应用程序在Bootstrap 4表中显示randomuser.me API中用户的JSON。
我目前正在将应用程序分解为组件。
<script>
const apiURL = "https://randomuser.me/api/";
import { onMount } from "svelte";
import { fade,fly } from 'svelte/transition';
import { flip } from 'svelte/animate';
import Search from './Search.svelte';
let users = [];
$:filteredUsers = users;
onMount(() => {
getUsers();
filterUsers();
});
const getUsers = () => {
let getFrom = "&results=20&inc=name,location,email,cell,picture";
fetch(`${apiURL}?${getFrom}`)
.then(res => res.json())
.then((data) => users = data.results);
};
const deleteUser = (user) => {
let itemIdx = filteredUsers.findindex(x => x == user);
filteredUsers.splice(itemIdx,1);
filteredUsers = filteredUsers;
}
</script>
<script>
export let stringToMatch = '';
export let filteredUsers = [];
export const filterUsers = () => {
filteredUsers = users;
if(stringToMatch){
filteredUsers = users.filter(user => {
return user.name.first.toLowerCase().includes(stringToMatch.toLowerCase())
|| user.name.last.toLowerCase().includes(stringToMatch.toLowerCase())
|| user.location.city.toLowerCase().includes(stringToMatch.toLowerCase());
});
}
}
</script>
<div class="search p-2">
<input class="form-control" type="text" placeholder="Search..." bind:value="{stringToMatch}" on:input="{filterUsers}">
</div>
即使我已从Search.svelte
导出变量并将te search组件导入到App.svelte
组件中,我仍然遇到filterUsers is not defined
错误,如 { {3}} 。
为什么会这样?什么是最快的修复程序?
解决方法
搜索组件应负责发出搜索项,或者您可以编写一个过滤后的函数并将其传递给搜索,但是您要在父级中调用子函数。据我所知export
确实很灵活。这意味着Child
个组件期望一个prop
实际上没有导出变量。您可以在https://svelte.dev/docs#1_export_creates_a_component_prop上了解有关组件通信的更多信息。
我对您的REPL进行了一些更改。您可以在这里找到它。
https://svelte.dev/repl/9da70df5e25646aabc5c37355b82c4a3?version=3.28.0