当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Elixir Kernel.pop_in用法及代码示例


Elixir语言中 Kernel.pop_in 相关用法介绍如下。

用法一

pop_in(path)
(宏)

通过给定的 path 从嵌套结构中弹出一个键。

这类似于 pop_in/2 ,除了路径是通过宏提取而不是传递列表。例如:

pop_in(opts[:foo][:bar])

相当于:

pop_in(opts, [:foo, :bar])

请注意,为了使此宏工作,完整路径必须始终对此宏可见。有关支持的路径表达式的更多信息,请查看 get_and_update_in/2 文档。

例子

iex> users = %{"john" => %{age: 27}, "meg" => %{age: 23}}
iex> pop_in(users["john"][:age])
{27, %{"john" => %{}, "meg" => %{age: 23}}}

iex> users = %{john: %{age: 27}, meg: %{age: 23}}
iex> pop_in(users.john[:age])
{27, %{john: %{}, meg: %{age: 23}}}

如果任何条目返回 nil ,则其键将被删除,删除将被视为成功。

用法二

pop_in(data, keys)
@spec pop_in(data, [Access.get_and_update_fun(term(), data) | term(), ...]) ::
  {term(), data}
when data: Access.container()

从给定的嵌套结构中弹出一个键。

除非 key 是函数,否则使用 Access 协议根据给定的 keys 遍历结构。如果键是一个函数,它将按照 get_and_update_in/3 中的指定调用。

例子

iex> users = %{"john" => %{age: 27}, "meg" => %{age: 23}}
iex> pop_in(users, ["john", :age])
{27, %{"john" => %{}, "meg" => %{age: 23}}}

如果任何条目返回 nil ,则其键将被删除,删除将被视为成功。

iex> users = %{"john" => %{age: 27}, "meg" => %{age: 23}}
iex> pop_in(users, ["jane", :age])
{nil, %{"john" => %{age: 27}, "meg" => %{age: 23}}}

相关用法


注:本文由纯净天空筛选整理自elixir-lang.org大神的英文原创作品 Kernel.pop_in(path)。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。