Enum freya::prelude::TemplateNode  
pub enum TemplateNode<'a> {
    Element {
        tag: &'a str,
        namespace: Option<&'a str>,
        attrs: &'a [TemplateAttribute<'a>],
        children: &'a [TemplateNode<'a>],
    },
    Text {
        text: &'a str,
    },
    Dynamic {
        id: usize,
    },
    DynamicText {
        id: usize,
    },
}Expand description
A statically known node in a layout.
This can be created at compile time, saving the VirtualDom time when diffing the tree
Variants§
Element
Fields
namespace: Option<&'a str>The namespace of the element
In HTML, this would be a valid URI that defines a namespace for all elements below it SVG is an example of this namespace
attrs: &'a [TemplateAttribute<'a>]A list of possibly dynamic attribues for this element
An attribute on a DOM node, such as id="my-thing" or href="https://example.com".
children: &'a [TemplateNode<'a>]A list of template nodes that define another set of template nodes
An statically known element in the dom.
In HTML this would be something like <div id="123"> </div>
Text
This template node is just a piece of static text
Dynamic
This template node is unknown, and needs to be created at runtime.
DynamicText
This template node is known to be some text, but needs to be created at runtime
This is separate from the pure Dynamic variant for various optimizations
Trait Implementations§
§impl<'a> Clone for TemplateNode<'a>
 
impl<'a> Clone for TemplateNode<'a>
§fn clone(&self) -> TemplateNode<'a>
 
fn clone(&self) -> TemplateNode<'a>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read more§impl<'a> Debug for TemplateNode<'a>
 
impl<'a> Debug for TemplateNode<'a>
§impl<'de, 'a> Deserialize<'de> for TemplateNode<'a>where
    'de: 'a,
 
impl<'de, 'a> Deserialize<'de> for TemplateNode<'a>where 'de: 'a,
§fn deserialize<__D>(
    __deserializer: __D
) -> Result<TemplateNode<'a>, <__D as Deserializer<'de>>::Error>where
    __D: Deserializer<'de>,
 
fn deserialize<__D>( __deserializer: __D ) -> Result<TemplateNode<'a>, <__D as Deserializer<'de>>::Error>where __D: Deserializer<'de>,
§impl<'a> Hash for TemplateNode<'a>
 
impl<'a> Hash for TemplateNode<'a>
§impl<'a> Ord for TemplateNode<'a>
 
impl<'a> Ord for TemplateNode<'a>
§fn cmp(&self, other: &TemplateNode<'a>) -> Ordering
 
fn cmp(&self, other: &TemplateNode<'a>) -> Ordering
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
    Self: Sized,
 
fn max(self, other: Self) -> Selfwhere Self: Sized,
§impl<'a> PartialEq<TemplateNode<'a>> for TemplateNode<'a>
 
impl<'a> PartialEq<TemplateNode<'a>> for TemplateNode<'a>
§fn eq(&self, other: &TemplateNode<'a>) -> bool
 
fn eq(&self, other: &TemplateNode<'a>) -> bool
self and other values to be equal, and is used
by ==.§impl<'a> PartialOrd<TemplateNode<'a>> for TemplateNode<'a>
 
impl<'a> PartialOrd<TemplateNode<'a>> for TemplateNode<'a>
§fn partial_cmp(&self, other: &TemplateNode<'a>) -> Option<Ordering>
 
fn partial_cmp(&self, other: &TemplateNode<'a>) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
 
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read more§impl<'a> Serialize for TemplateNode<'a>
 
impl<'a> Serialize for TemplateNode<'a>
§fn serialize<__S>(
    &self,
    __serializer: __S
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
    __S: Serializer,
 
fn serialize<__S>( &self, __serializer: __S ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where __S: Serializer,
impl<'a> Copy for TemplateNode<'a>
impl<'a> Eq for TemplateNode<'a>
impl<'a> StructuralEq for TemplateNode<'a>
impl<'a> StructuralPartialEq for TemplateNode<'a>
Auto Trait Implementations§
impl<'a> RefUnwindSafe for TemplateNode<'a>
impl<'a> Send for TemplateNode<'a>
impl<'a> Sync for TemplateNode<'a>
impl<'a> Unpin for TemplateNode<'a>
impl<'a> UnwindSafe for TemplateNode<'a>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
§impl<Q, K> Equivalent<K> for Qwhere
    Q: Eq + ?Sized,
    K: Borrow<Q> + ?Sized,
 
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Qwhere
    Q: Eq + ?Sized,
    K: Borrow<Q> + ?Sized,
 
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.source§impl<Q, K> Equivalent<K> for Qwhere
    Q: Eq + ?Sized,
    K: Borrow<Q> + ?Sized,
 
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
 
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.