- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有什么方法可以应用 Control-Lens-Setter.html#g:4 中提到的组合器/ setter 吗?当输入值(不是正在设置的字段)是Just x
时?
例如,考虑 (~+)
组合器,如果我有以下内容:
let target = (1, 2)
input1 = Just 10
input2 = Nothing
我想要一个执行以下操作的 setter:
(11, 2) == target & (_1 . someSetter) +~ input1
& (_2 . someSetter) +~ input2
在这种情况下,我试图避免使用 fmap
或 maybe/fromMaybe
,因为我有很多这样的操作要做,并且宁愿避免样板通过利用镜头的简洁性。
最佳答案
您始终可以定义自己的 setter。
maybeSetter :: (b -> a -> a) -> ASetter s t a a -> Maybe b -> s -> t
maybeSetter g f x = runIdentity . f (Identity . maybe id g x)
(+!) :: Num a => ASetter s t a a -> Maybe a -> s -> t
(+!) = maybeSetter (+)
let target = (1, 2)
input1 = Just 10
input2 = Nothing
in
(11, 2) == target & (_1 . someSetter) +! input1
& (_2 . someSetter) +! input2
您还可以轻松定义其他 setter 。
(-!) :: Num a => ASetter s t a a -> Maybe a -> s -> t
(-!) = maybeSetter subtract
(||!) :: ASetter s t Bool Bool -> Maybe Bool -> s -> t
(||!) = maybeSetter (||)
(<>!) :: Semigroup a => ASetter s t a a -> Maybe a -> s -> t
(<>!) = maybeSetter (flip (<>))
(.!) :: ASetter s t a a -> Maybe a -> s -> t
(.!) = maybeSetter const
(%!) :: ASetter s t a a -> Maybe (a -> a) -> s -> t
(%!) = maybeSetter id
这就是镜头的妙处。它们只是常规函数。
关于haskell - 仅当输入值为 "setter"时应用镜头 "Just x"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58110197/
我很困惑为什么我在 GHCi 中得到了这个 :t sequence [Just,Just] sequence [Just, Just] :: a -> [Maybe a] 说详细点,可以理解seque
我怎样才能做到以下几点。例如,如果我想减去 Just 8 - Just 5 得到 Just 3,我该怎么做? Just 8 - Just 5 = Just 3 Just 15 - Just 9 = J
Define a function pairMaybe :: Maybe a -> Maybe b -> Maybe (a,b) that produces a Just result only
已关闭。这个问题是 off-topic 。目前不接受答案。 想要改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 已关闭10 年前。 Improve th
我有一个我应该这样定义的函数: func :: (a -> Maybe [b]) -> [a] -> Maybe [b] 它应该如何工作的一些示例: func (\x -> if x == 0 the
我们的电子商务网络应用程序中的多个页面允许用户过滤他们提交给我们的请求的状态列表。 过滤器通常是这样的: 所有待完成 我们将它们设置为链接。我们想设置它们的样式,以便当前事件的过滤器用彩色矩形突出显示
我知道括号会强制执行不同的操作顺序,但我不太明白第一个结果: >> (fmap length Just) [1, 2, 3] 1 而以下内容非常有意义 - 我们将长度函数提升到 Just 结构上,因此
我是一个绝对的初学者。使用 emacs 浏览 LYAH。 我目前的设置: Ubuntu 12.04 LTS(使用体验 - 初学者) GNU Emacs 23(使用经验 - 初学者) 能够在haskel
目前我正在学习 Haskell,并且坚持将类型实例化为类型类。我实际上不明白,为什么可以使用 Maybe a 创建 Just (+) 类型的值。 为什么这对我来说很奇怪的问题是,Maybe 类型被定义
基本上我希望 sub.domain.com 重定向到 domain.com,但只有那个 url。例如 sub.domain.com/page 应该仍然加载而不重定向。我怎样才能做到这一点 .htacc
我的问题是由 this 触发的关于 SO 的讨论,这并没有导致真正解释该问题的答案。我在这里以稍微不同的方式“重写”它,因为我想让它更清楚真正的问题是什么,因此希望在这里得到答案。 考虑以下两个 Ru
我是iPhone编程的新手。任何帮助将不胜感激 :) 当我从obj-c方法或C函数中启动新的NSThread时,一切正常: [NSThread detachNewThreadSelector:@sel
Visual Studio 有一个选项(在“调试/常规”下)“仅启用我的代码” 什么是“只是我的代码”? Visual Studio 没有解释该功能。 最佳答案 来自Visual Studio Doc
我以为这是工作原理,好像我丢失了一些东西。 @Test fun singleCompletes() { val testSubscriber = TestSubscriber() Si
我在将 Maybe 列表转换为字符串列表时遇到问题。 我的列表看起来像这样:[没有,只有 3,只有 9,没有,没有]。 我想将所有 Nothing 替换为点('.'),并将所有 Just Int 替换
我有以下代码: doIf :: (a -> IO ()) -> Maybe a -> IO () doIf f x = case x of Just i -> f i Nothing -> r
为什么这个工作... Just.(+3) $ 6.7 Just $ truncate 8.9 ...但不是这个? Just.truncate $ 8.9 我尝试将截断解析为一个简单的 Double -
[编辑] 我在numbtongue之后重建了我的代码暗示。现在看起来完全不同了,而且运行得很好。只不过它只能工作一次!滚了一圈之后就不再滚了...我有两种功能:一种用于过渡,另一种用于替换内容。在“t
我正在为 MySQL 服务器执行以下 SQL 脚本。它是创建一个接受类(class)代码和开始日期作为参数的 SPROC,然后在连续的工作日为每个模块添加类(class)。 DELIMITER
我很困惑。我有一个方法可以做一些长时间的工作(大约 5 秒)并返回一个 String 作为结果。我将该函数包装到一个 Observable smth 中,如下所示: private Observabl
我是一名优秀的程序员,十分优秀!