All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.meterware.httpunit.HTMLElement Maven / Gradle / Ivy

The newest version!
package com.meterware.httpunit;
/********************************************************************************************************************
 * $Id$
 *
 * Copyright (c) 2002-2008, Russell Gold
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
 * documentation files (the "Software"), to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and
 * to permit persons to whom the Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all copies or substantial portions
 * of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO
 * THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
 * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 * DEALINGS IN THE SOFTWARE.
 *
 *******************************************************************************************************************/
import com.meterware.httpunit.scripting.ScriptingEventHandler;
import com.meterware.httpunit.scripting.ScriptingHandler;
import com.meterware.httpunit.scripting.ScriptableDelegate;

import org.w3c.dom.Element;
import org.w3c.dom.Node;

/**
 * An interface which defines the common properties for an HTML element, which can correspond to any HTML tag.
 *
 * @since 1.5.2
 * @author Russell Gold
 **/
// TODO activate the extends Element as
// in http://www.w3.org/TR/REC-DOM-Level-1/java-language-binding.html
//public interface HTMLElement extends Element,ScriptingEventHandler {
public interface HTMLElement extends ScriptingEventHandler {

    /**
     * Returns the ID associated with this element. IDs are unique throughout the HTML document.
     **/
     String getID();


    /**
     * Returns the class associated with this element.
     **/
    String getClassName();


    /**
     * Returns the name associated with this element.
     **/
    String getName();


    /**
     * Returns the title associated with this element.
     **/
    String getTitle();


    /**
     * Returns the value of the attribute of this element with the specified name.
     * Returns the empty string if no such attribute exists.
     *
     * @since 1.6
     */
    String getAttribute( String name );

    /**
     * Set the value of the attribute of this element with the specified name.
     * @since 1.7
     */ 
    void setAttribute( String name, Object value );
     
    /**
     * Remove the attribute of this element with the specified name.
     * @since 1.7
     */ 
    void removeAttribute( String name );
    
    /**
     * Returns true if this element may have an attribute with the specified name.
     *
     * @since 1.6
     */
    boolean isSupportedAttribute( String name );
    

    /**
     * Returns the delegate which supports scripting this element.
     */
    ScriptingHandler getScriptingHandler();


    /**
     * Returns the contents of this element, converted to a string.
     *
     * @since 1.6
     */
    String getText();


    /**
     * Returns the tag name of this node.
     *
     * @since 1.6.1
     */
    String getTagName();


    ScriptableDelegate newScriptable();

    /**
     * Returns the scriptable delegate which can provide the scriptable delegate for this element.
     */
    ScriptableDelegate getParentDelegate();

    /**
     * Returns the DOM node underlying this element.
     */
    Node getNode();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy