| Browser interfaceBrython-specific built-in modulesWorking with BrythonCookbook | Elements attributes, properties and methodsDOM attributes and propertiesThe DOM defines two different concepts for elements :
The DOM also defines a relation between some attributes and some
properties: attributes, which are defined in the HTML (or SVG) tag : for instance,
  <img src="icon.png">defines the attributesrcof the element created
  by the<img>tag properties, that can be attached to an element by the dotted syntax : set
  by element.property_name = value, read byvalue = element.property_name 
Besides the attributes defined by the specification for a given tag, custom
attributes can be defined (template engines use this a lot) ; for these
attributes, the property of the same name is not set. Custom properties can
also be defined for an element, and this doesn't set the attribute of the
same name.
Attribute values are always strings, while property values can be of any type.
Attributes are case-insensitive for HTML elements and case-sensitive for SVG
elements ; properties are always case-sensitive. generally, for the attributes that are expected for a given tag
  (eg "id" or "class" for any kind of tag, "src" for IMG tags, "href" for A
  tags, etc), when the attribute is set, the property is also set
 most of the time, the property name is the same as the attribute name, but
  there are exceptions : the property for the attribute "class" is "className"
 generally, the property value is the same as the attribute value, but not
  always : for instance, for an element defined by
  <INPUT type="checkbox" checked="checked">, the value of the attribute
  "checked" is the string "checked", and the value of the property "checked"
  is the booleantrue Attributes and properties management in BrythonBrython manages DOM attributes with the attributeattrsofDOMNodeinstances ; it manages properties with the dotted syntax.element.attrsis a dictionary-like object.# set a value to an attribute
element.attrs[name] = value
# get an attribute value
value = element.attrs[name] # raises KeyError if element has no attribute
                            # "name"
value = element.attrs.get(name, default)
# test if an attribute is present
if name in element.attrs:
    ...
# remove an attribute
del element.attrs[name]
# iterate on the attributes of an element
for name in element.attrs:
    ...
for attr in element.attrs.keys():
    ...
for value in element.attrs.values():
    ...
for attr, value in element.attrs.items():
    ...Brython-specific properties and methodsFor convenience, Brython defines a few additional properties and methods:
(1) On page load, properties
| Name | Type | Description | R = read only R/W =
read + write
 |  
| abs_left | integer | position of the element relatively to the document left border (1) | R |  
| abs_top | integer | position of the element relatively to the document top border (1) | R |  
| bind | method | event binding, see the section events | - |  
| children | list | the element's children of type element (not text) | R |  
| child_nodes | list | the element's children of any type | R |  
| class_name | string | the name of the element's class (tag
attribute class) | R/W |  
| clear | method | removes all the
descendants of the elementelt.clear() | - |  
| closest | method | elt.closest(tag_name)returns the first parent element ofeltwith the specified tag name. RaisesKeyErrorif no element is found. | - |  
| get | method | selects elements (cf access to elements) | - |  
| height | integer | element height in pixels (2) | R/W |  
| html | string | the HTML code inside the element | R/W |  
| index | method | elt.index([selector])returns the index (an integer) of the element
among its parent's children. If selector is specified, only the elements
matching the CSS selector are taken into account ; in this case, if no
element matches, the method returns -1. | - |  
| inside | method | elt.inside(other)tests ifeltis
contained inside elementother | - |  
| left | integer | the position of the element relatively to
the left border of the first positioned parent (3) | R/W |  
| parent | DOMNodeinstance | the element's parent ( Nonefordoc) | R |  
| scrolled_left | integer | position of the element relatively to the left border of the visible part of the document (1) | L |  
| scrolled_top | entier | position of the element relatively to the top border of the visible part of the document (1) | L |  
| select | method | elt.select(css_selector)returns the elements matching the specified CSS selector | - |  
| select_one | method | elt.select_one(css_selector)returns the elements matching the specified CSS selector, otherwiseNone | - |  
| text | string | the text inside the element | R/W |  
| top | integer | the position of the element relatively to
the upper border of the first positioned parent (3) | R/W |  
| width | integer | element width in pixels (2) | R/W |  abs_leftandscrolled_leftof an element are
the same, and the same forabs_topandscrolled_top. If the document is
scrolled down by n pixels,abs_topalways keeps the same value butscrolled_topis decremented by n
(2) Same asstyle.heightandstyle.widthbut as integers.
(3) When going up the DOM tree, we stop at the first parent whose attributestyle.positionis set to a value different of "static".leftandtopare
computed likestyle.leftandstyle.topbut are integers, not strings ending
withpx.
To add a child to an element, use the operator <= (think of it as a left
arrow for assignment)from browser import document, html
document['zone'] <= html.INPUT(Id="data")Iterating on an element's children can be done using the usual Python syntax : for child in element:
    ...To destroy an element, use the keyword del del document['zone']The optionscollection associated with a SELECT object has an interface of a
 Python list :
 access to an option by its index : option = elt.options[index] insertion of an option at the index position : elt.options.insert(index,option) insertion of an option at the end of the list : elt.options.append(option) deleting an option : del elt.options[index] |