pub enum JsOption<T> {
Some(T),
Null,
Undefined,
}
Expand description
An Option
-like type with two data-less variants in addition to Some
:
Null
and Undefined
.
Variants§
Implementations§
Source§impl<T> JsOption<T>
impl<T> JsOption<T>
Sourcepub fn from_option(opt: Option<T>) -> Self
pub fn from_option(opt: Option<T>) -> Self
Construct a JsOption
from a regular Option
.
None
will be converted to to Null
.
Sourcepub fn from_implicit_option(opt: Option<T>) -> Self
pub fn from_implicit_option(opt: Option<T>) -> Self
Construct a JsOption
from a regular Option
.
None
will be converted to Undefined
.
Sourcepub fn into_option(self) -> Option<T>
pub fn into_option(self) -> Option<T>
Convert a JsOption
to Option
.
Sourcepub fn into_nested_option(self) -> Option<Option<T>>
pub fn into_nested_option(self) -> Option<Option<T>>
Convert a JsOption<T>
to Option<Option<T>>
.
Null
is represented as Some(None)
while Undefined
is represented
as None
.
Sourcepub const fn is_undefined(&self) -> bool
pub const fn is_undefined(&self) -> bool
Returns true
if the JsOption
is Undefined
.
Sourcepub fn unwrap(self) -> T
pub fn unwrap(self) -> T
Returns the contained Some
value, consuming the self
value.
§Panics
Panics if the self value equals Null
or Undefined
.
Sourcepub fn unwrap_or(self, default: T) -> T
pub fn unwrap_or(self, default: T) -> T
Returns the contained Some
value or a provided default.
Sourcepub fn unwrap_or_else<F: FnOnce() -> T>(self, f: F) -> T
pub fn unwrap_or_else<F: FnOnce() -> T>(self, f: F) -> T
Returns the contained Some
value computes is from a closure.
Source§impl<T: Default> JsOption<T>
impl<T: Default> JsOption<T>
Sourcepub fn unwrap_or_default(self) -> T
pub fn unwrap_or_default(self) -> T
Returns the contained Some
value or a default.
Trait Implementations§
Source§impl<'de, T> Deserialize<'de> for JsOption<T>where
T: Deserialize<'de>,
impl<'de, T> Deserialize<'de> for JsOption<T>where
T: Deserialize<'de>,
Source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
Deserialize a JsOption
.
This implementation will never return Undefined
. You need to use
#[serde(default)]
to get Undefined
when the field is not present.