AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

    • Início
    • system&network
    • Ubuntu
    • Unix
    • DBA
    • Computer
    • Coding
    • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / 问题

Perguntas[svelte](coding)

Martin Hope
Valentin Vignal
Asked: 2025-04-26 21:17:16 +0800 CST

Como simular $env/static/public com vitest?

  • 5

Estou usando uma variável env MY_VARque uso de$env/static/public

import { MY_VAR } from '$env/static/public';

export const myVar = MY_VAR === 'true';

Gostaria de simular isso em alguns testes, para suportar os dois cenários: MY_VARbuild true/ false. Mas não consigo. Estou usando o vitest.

Tentei configurar um arquivo simulado __mock__/env/static/public.tscom:

export const MY_VAR = 'false';

com vitest.config.ts:

export default defineConfig(({ mode }) => ({
    // ...
    resolve: {
        alias: {
            '$env/static/public': path.resolve(__dirname, '__mocks__/env/static/public')
        }
    }
}));

Também tentei algumas combinações de vi.mock, vi.hoisted, vi.spyOnmas não consegui fazer funcionar.

Como posso simular $env/static/publiccom vitest?

svelte
  • 1 respostas
  • 21 Views
Martin Hope
Muhammad Najid
Asked: 2025-04-24 22:14:25 +0800 CST

passando os dados do layout.ts das crianças para o layout.svelte dos pais

  • 4

Então, tenho trabalhado na implementação do recurso de trilhas de navegação no meu webapp sveltekit.

  1. A ideia é que o breadcrumb seja renderizado no topo do layout.svelte.
  2. E então os descendentes subsequentes, de alguma forma, passarão seus dados de navegação para o pai.
  3. Isso é útil quando tenho uma rota de descanso em algum lugar.
  4. Consegui fazer funcionar. Mas acho que pode haver uma maneira melhor de lidar com isso.
  5. exemplo prático -> [https://stackblitz.com/edit/sveltejs-kit-template-default-2o46jwja?file=src%2Froutes%2Ffolders%2F%5B...rest%5D%2F%2Bpage.svelte][1]
  6. Como você pode ver, estou fazendo isso usando vanilla js, então o armazenamento não é reativo, já que o inicializei em layout.ts. Isso significa que não será útil para armazenar dados reativos posteriormente.

Seria bom se alguém pudesse compartilhar suas experiências caso tenha encontrado algo parecido com isso.

svelte
  • 1 respostas
  • 33 Views
Martin Hope
Seva Golovanov
Asked: 2025-04-22 05:31:32 +0800 CST

Declare um snippet dentro de um componente sem que ele seja passado implicitamente ao componente como um prop

  • 5

O tutorial do Svelte demonstra como declarar um trecho de linha de tabela:

<tbody>
    {#snippet monkey()}...{/snippet}

    {@render monkey()}
</tbody>

Até aqui, tudo bem. Faz sentido colocar um trecho perto de onde ele está sendo usado — um trecho de linha de tabela realmente pertence a tbody.

Também quero reutilizar um trecho de linha de tabela. Só que eu uso a biblioteca de componentes Flowbite Svelte. Então o código fica assim:

<Table>
    ...
    <TableBody>
        {#snippet row(row: UserProductListEntry)}
            {row.product.title}
        {/snippet}

Isso funciona em tempo de execução, mas tem problemas porque o snippet se torna implicitamente a prop do TableBody:

  1. Estou recebendo este erro do tipo: Erro IDE Este é um erro do plugin IDEA Svelte? Não há nenhuma referência, por exemplo, ao ESLint. Deveria ser um aviso e/ou algo passível de supressão? Não encontrei nada parecido no rastreador de problemas da JetBrains.
  2. (Menos importante) Neste caso, não pretendo passar o snippet para TableBody como uma propriedade. E se por acaso esperar um snippet com o mesmo nome?

Então a questão é: existe uma maneira de impedir que esse trecho se torne uma propriedade implícita? Ou pelo menos lidar com o problema 1 de alguma forma, sem mover o trecho para fora do TableBody e da Table?

svelte
  • 1 respostas
  • 21 Views
Martin Hope
Seva Golovanov
Asked: 2025-04-21 04:24:51 +0800 CST

Como invalidar um cache arbitrário?

  • 6

Tenho um simples +page.tsmostrando a datastring e fornecendo o botão "Atualizar":

<script lang="ts">
    import { invalidateAll } from '$app/navigation';

    const { data } = $props();
</script>

<p>Data: {data.data}</p>
<button onclick={() => invalidateAll()}>Update</button>

Tenho um universal loadque +page.tsprefere usar algum tipo de Cache - aqui é apenas um campo estático em uma classe:

export async function load() {
    let data = Cache.getData();
    if (data) {
        console.log('Found cached data');
    } else {
        console.log('No cached data - fetching');
        data = 'Fresh new data';
        Cache.setData(data);
    }

    return {
        data
    };
}

class Cache {
    static data?: string;

    static getData() {
        return this.data;
    }

    static setData(data: string) {
        this.data = data;
    }

    static clear() {
        this.data = undefined;
    }
}

console.log('Initializing cache');
Cache.setData('Old cached data');

Por padrão, a única maneira de contornar esse cache é o usuário solicitá-lo explicitamente pressionando o botão "Atualizar". Mas como posso saber quando o erro loadé causado por invalidação e não pelo carregamento inicial da página para limpar o cache? Ou talvez, mais especificamente, pressionando o botão "Atualizar"? Em outras palavras, o que posso inserir ifaqui:

export async function load() {
    if (/* what goes here? */) {
        Cache.clear();
    }

    ...

O ideal é que eu procure uma maneira universal, não algo complicado como definir um windowcampo para CSR ou um cabeçalho de solicitação para SSR. Poderia ser algo relacionado à rota, um parâmetro de consulta? Mas como definir isso para a chamada invalidateor invalidateAll?

svelte
  • 1 respostas
  • 32 Views
Martin Hope
tobiasBora
Asked: 2025-04-04 17:41:14 +0800 CST

Por que o Svelte não grava os sinais individualmente?

  • 5

Estou pensando sobre os internos do Svelte para projetar adequadamente meu aplicativo para ter eficiência máxima (posso lidar com (dezenas?) de milhares de elementos para atualizar, então eficiência importa), notavelmente com como a reatividade é implementada. Então, usando este pequeno exemplo (no link você pode inspecionar o código JS na aba direita), implementei este código básico:

<script>
    let foo = $state(42);
    let bar = $state(52);
</script>

<div onclick={() => foo = foo + 2}>
    Hello {foo}
</div>
<span onclick={() => bar = bar + 1}>
    Hello {bar}
</span>

e obtenho o seguinte JavaScript compilado:

import 'svelte/internal/disclose-version';
import * as $ from 'svelte/internal/client';

var on_click = (_, foo) => $.set(foo, $.get(foo) + 2);
var on_click_1 = (__1, bar) => $.set(bar, $.get(bar) + 1);
var root = $.template(`<div> </div> <span> </span>`, 1);

export default function App($$anchor) {
    let foo = $.state(42);
    let bar = $.state(52);
    var fragment = root();
    var div = $.first_child(fragment);

    div.__click = [on_click, foo];

    var text = $.child(div);

    $.reset(div);

    var span = $.sibling(div, 2);

    span.__click = [on_click_1, bar];

    var text_1 = $.child(span);

    $.reset(span);

    $.template_effect(() => {
        $.set_text(text, `Hello ${$.get(foo) ?? ''}`);
        $.set_text(text_1, `Hello ${$.get(bar) ?? ''}`);
    });

    $.append($$anchor, fragment);
}

$.delegate(['click']);

O que parece importante é o código:

    $.template_effect(() => {
        $.set_text(text, `Hello ${$.get(foo) ?? ''}`);
        $.set_text(text_1, `Hello ${$.get(bar) ?? ''}`);
    });

Se meu entendimento de sinais estiver correto (eu segui esta ótima postagem para entender como os sinais são implementados), isso executará a função de retorno de chamada toda vez que um sinal mudar internamente... mas o problema é que se barmudar, o código $.set_text(text, `Hello ${$.get(foo) ?? ''}`);também mudará, ou seja, mudar um sinal aciona operações O(n) onde n é o número de sinais... Com 2 elementos isso não é muito, mas se eu tiver dezenas de milhares de elementos, temo ter um tempo de atualização não desprezível.

Então eu tenho duas perguntas:

  1. Por que o Svelte não implementa um retorno de chamada por sinal para ter uma complexidade O(1) independente do número de sinais?
  2. Além disso, a mesma ideia é seguida por observable? Meu objetivo final é entender a complexidade das atualizações no liveQueryobservable do Dexie.js.
svelte
  • 1 respostas
  • 13 Views
Martin Hope
Loïc Boset
Asked: 2025-03-08 19:07:45 +0800 CST

O formulário Svelte page.form é indefinido quando desestruturado

  • 6

Estou criando um componente de formulário simples seguindo a documentação do Svelte, que diz que posso acessar os dados de ação do formulário de um componente externo usando o estado da página.

Quando eu desestruturo formo estado da página, ela fica indefinida.

No entanto, posso acessá-lo se o fizer page.formdiretamente.

Por que isso? O que estou perdendo?

<script lang="ts">
    import { enhance } from "$app/forms";
    import { page } from "$app/state";

  let pageDate = page; // pageDate.form is defined
  // let { form } = page; -> form is undefined
</script>

<h3>Login</h3>

{#if pageDate.form?.error}
  <p class="error">{pageDate.form?.error}</p>
{/if}

<form method="POST" action="?/login" use:enhance>
    <label>
        Email
        <input name="email" type="email">
    </label>
    <label>
        Password
        <input name="password" type="password">
    </label>
    <button>Log in</button>
</form>
svelte
  • 1 respostas
  • 13 Views
Martin Hope
AlexAngc
Asked: 2025-03-08 00:43:25 +0800 CST

Converter sintaxe de herança de componente para componente de função Svelte 5

  • 5

Estou migrando minha base de código do Svelte 4 para o Svelte 5.

Eu tinha o seguinte código:

import MarkdownLinkRenderer from '$lib/MarkdownLinkRenderer.svelte';

export function createMarkdownLinkRenderer(styles: string) {
  return class extends MarkdownLinkRenderer {
    constructor(options: { target: Element; props: { href: string; text: string } }) {
      super(options);
      this.$set({ className: styles });
    }
  };
}

Que foi usado como renderizador com o svelte-markdownpacote (substituído por @humanspeak/svelte-markdownpara compatibilidade com Svelte 5) :

<script lang="ts">
  const renderers = {
    link: createMarkdownLinkRenderer('text-blue-56 hover:underline')
  };
</script>

<Markdown source={notification.message} options={{ gfm: true, breaks: true }} {renderers} />

Como posso converter meu createMarkdownLinkRendererpara funcionar com o Svelte 5, já que componentes não são mais classes?

svelte
  • 1 respostas
  • 23 Views
Martin Hope
Zied Hamdi
Asked: 2025-02-13 06:20:57 +0800 CST

Como acionar $effect() com variáveis ​​vinculadas no Svelte?

  • 5

Tenho uma variável que está corretamente vinculada ao seu pai: seu valor muda ao clicar, e esse valor é exibido corretamente tanto no pai quanto no filho vinculado. Você pode testar isso no playground svelte: https://svelte.dev/playground/c2fea05c50394c1199d31aa525df5418?version=5.19.10

+página.esbelto

<script lang='ts'>
    import Foo from './Foo.svelte'
    
    let page = $state({value:12});  
    
    $effect(() => {
    console.log("Updating page: ", $inspect(page));
  });
</script>

<div>
  <Foo bind:page={page} />
    App page is {page.value}
</div>

Foo.svelte (criança)

<script>    
    let {page =$bindable()} = $props();

</script>

<button onclick={()=>page.value = page.value+1}>
    Value in Foo is {page.value}: click me
</button>
<br/>

Apesar da rerenderização estar acontecendo, meu $effect() que usa a mesma variável de mudança não é chamado. Como posso detectar que uma mudança aconteceu na minha página (a ideia é que eu desenvolvi um arquivo ts que salva automaticamente os dados na mudança, e não consigo encontrar uma maneira de ser notificado sobre as mudanças.

ps: salvar uma página em uma loja também precisaria que eu detectasse que uma mudança aconteceu, e como meu objeto tem dezenas de campos, não quero disparar manualmente um evento na mudança. Alguma ideia de como fazer isso?

Solução baseada na resposta de Brunnerh:

"apenas referenciar o objeto não acionará nada (a menos que ocorra uma reatribuição da variável)."

E disse, vamos tentar algo estúpido (porque, se o método não for chamado, então isso nunca deveria acontecer, certo?). Mas na verdade resolveu o problema, pois o efeito é considerado digno de ser chamado agora:

$effect(() => {
    console.log("Updating page: ", $inspect(page));
    autoSave.update(page = {...page})
});

Ainda é muito contraintuitivo, não acho isso explícito o suficiente. Um identificador para dizer "forçar efeito mesmo se não houver gravações acontecendo" seria melhor compreendido, eu acho

svelte
  • 1 respostas
  • 16 Views
Martin Hope
Alexander Juhl
Asked: 2025-02-12 22:45:13 +0800 CST

Markdown-it-katex - como fazer sobrescrito?

  • 5

Este é meu código (Svelte 5, sveltekit, tailwind):

<script lang="ts">
    import MarkdownIt from 'markdown-it';
    import markdownItKatex from 'markdown-it-katex';
    import 'katex/dist/katex.min.css';

    const md = new MarkdownIt({ html: false, linkify: true, typographer: true });
    md.use(markdownItKatex, { throwOnError: false, errorColor: ' #cc0000' });

    function renderMarkdown(content: string) {
        return md.render(content);
    }

    let content: string = '$a^2+b^2=c^2$';
</script>

<h1>markdown-it-katex</h1>
<div>{@html renderMarkdown(content)}</div>

<style>
</style>

Minha saída é:

a2+b2=c2

Mas os números (2) estão rebaixados (subscrito). Como posso deixar os números em sobrescrito?

svelte
  • 1 respostas
  • 19 Views
Martin Hope
Keygun2k1
Asked: 2025-01-13 23:27:22 +0800 CST

Como usar diretivas svelte em componentes que usam runas svelte?

  • 5

Tenho este componente svelte que atualmente está usando a use:diretiva de svelte runes:

<script>
    import {route} from "@mateothegreat/svelte5-router";

    let {children, className, ...rest} = $props();
</script>

<a
        use:route
        class={`btn ${className}`}
        {...rest}
>
    {@render children()}
</a>

Ao tentar passá-lo como prop, recebo um erro de renderização: "Svelte: Este tipo de diretiva não é válido em componentes". Aqui está como estou tentando usar a diretiva como prop:

<ButtonLink
       onclick={() => $currentRoute = window.location.pathname}
       href={href}
       class:active={isActive}
    >

O class:active={isActive}está dando o erro. Existe uma maneira de passar o uso de diretivas para um componente em runas svelte? Se sim, como e o que estou fazendo errado?

svelte
  • 1 respostas
  • 27 Views

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help
subwaysurfers
my femboy roommate

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve