javascript - 是什么导致这个小型 Svelte 应用程序出现 "ctx[1] is not a function"错误?

标签 javascript svelte

我正在使用 Svelte 开发一个小型的待办事项应用程序。我从 jsonplaceholder 中列出了 10 个待办事项。

我在 App.svelte 中有这个:

<script>
    import { onMount } from "svelte";
    import Header from './Header.svelte';
    import ToDoList from './ToDoList.svelte';
    import Footer from './Footer.svelte';
    const apiURL = "https://jsonplaceholder.typicode.com/todos";
    const limit = 10;
    let todos = [];
    export let unsolvedTodos = [];
    
    onMount(() => {
        getTodos();
    });
    
    const getTodos = () => {
        fetch(`${apiURL}?&_limit=${limit}`)
        .then(res => res.json())
        .then((data) => todos = data)
        .then(getUnsolvedTodos);
    }
    
    const getUnsolvedTodos = () => {
        unsolvedTodos = todos.filter(todo => {
            return todo.completed === false;
        })
    }

    const deleteTodo = (todo) => {
        let itemIdx = todos.findIndex(x => x == todo);
        todos.splice(itemIdx, 1);
        todos = todos;
  }
</script>

<div class="app-wrapper">
  <div id="toDoApp">
        <Header />
    <ToDoList todos={todos} />
    <Footer />
  </div>
</div>

在 ToDoList.app 中:

<script>
    import TodoItem from './TodoItem.svelte';
    export let todos;
    let deleteTodo;
</script>

{#if todos.length > 0}
  <ul class="todo-list">
    {#each todos as todo, index}
        <TodoItem {todo} on:deleteTodo = {deleteTodo(todo)} />
    {/each}
  </ul>
{/if}

在 TodoItem.svelte 中:

<script>
    import {createEventDispatcher} from 'svelte';
    import { fade, fly } from 'svelte/transition';
    import { flip } from 'svelte/animate';
    export let todo;
    
    const dispatch = createEventDispatcher();
    const Delete = () => dispatch("deleteTodo", todo);
</script>

<li transition:fly="{{x:-100, duration:200}}">
    <input type="checkbox" checked="{todo.completed}" />
    <span class="title {todo.completed ? 'done' : ''}">{todo.title}</span>
    <button on:click="{Delete}"><i class="fa fa-trash" aria-hidden="true"></i></button>
</li>

我一定是遗漏了一些东西,因为我得到了错误 ctx[1] is not a function 可以在这个 REPL 中看到.

我做错了什么?

最佳答案

ToDoList.svelte 中,您正在调用 deleteTodo(todo)deleteTodo 未定义。 Svelte 真的应该在这里抛出更好的错误消息......

编辑:

此外,如果您分配一个事件处理程序,您希望传递对函数的引用,例如 on:deleteTodo = {() => deleteTodo(todo)}on: deleteTodo = {deleteTodo} 并且不直接调用该函数。

关于javascript - 是什么导致这个小型 Svelte 应用程序出现 "ctx[1] is not a function"错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67577252/

相关文章:

javascript - Selenium C# : Locate element on chart

javascript - 如何将 Raycaster 与组合相机一起使用?

typescript - 如何在 Typescript 文件中导入 Svelte 组件?

node.js - Svelte/Sapper - 遇到与 Luxon 和 Lodash 构建相关的错误

javascript - 如何使用 css 定位 svelte 中的组件?

javascript - 在 https 上为 localhost 提供服务时,SvelteKit 页面每 3-4 秒重新加载一次页面

sass - 如何解决(插件 postcss)Error : File to import not found or unreadable: smui-theme. Material UI Svelte 项目

javascript - 如何给 HTML 标签编号?

javascript - jQuery 模态窗口在 Internet Explorer 中错误关闭

php - 使用变量作为高度和宽度的值