elixir - handle_event 不适用于 Phoenix LiveView 示例
问题描述
https://github.com/katpavan/liveview-testapp/blob/master/lib/liveviewapp_web/live/foo_live.ex
foo_live.ex:
defmodule LiveviewappWeb.FooLive do
use LiveviewappWeb, :live_view
require Logger
@impl true
def mount(_params, _session, socket) do
{:ok, assign(socket, msg: "this is a message", results: %{})}
end
def render(assigns) do
~L"""
<h1>Hello</h1>
<div phx-keydown="keydown" phx-target="window">
<%= @msg %>
</div>
"""
end
def handle_event("keydown", %{"key" => key}, socket) do
Logger.debug "Var value: #{inspect(key)}"
{:noreply, assign(socket, msg: key)}
end
end
这是我进入页面时看到的。但是当我单击 div 中的文本并键入时,handle_event 不会触发。
解决方案
有几种方法可以实现这一点:
设置
tabview=0
为 div,有关详细信息,请参阅此答案:<div id="test" phx-keydown="keydown" tabindex="0">
但是,使用
phx-window-keydown
会使句柄全局化:<div id="test" phx-window-keydown="keydown">
推荐阅读
- python - DBSCAN 轮廓系数:这个 for 循环有效吗?
- python-3.x - 对于奇数长度列表而不是偶数长度列表,卡在 while 循环中的 perfect_shuffle_counter
- java - 来自数组的统计程序
- php - 上传时,根据填写的单元格重命名文件
- java - 类型对象未定义方法 gettext() 的编译错误,需要 Cast
- angular - ngFor 循环中的单个 ngClass,角度 6
- c++ - C++ 模拟脉冲序列序列
- ios - 如何在不规则图形上添加圆角?
- sed - 我的 sed 命令和引号有什么问题?
- c# - 使用 JObject 和 LINQ 反序列化 JSON