/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* vim: set ts=8 sts=2 et sw=2 tw=80: */ /* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #ifndef mozilla_dom_HTMLOptionsCollection_h #define mozilla_dom_HTMLOptionsCollection_h
class DocGroup; class HTMLElementOrLong; class HTMLOptionElementOrHTMLOptGroupElement; class HTMLSelectElement;
/** * The collection of options in the select (what you get back when you do * select.options in DOM)
*/ class HTMLOptionsCollection final : public nsIHTMLCollection, public nsWrapperCache { typedef HTMLOptionElementOrHTMLOptGroupElement HTMLOptionOrOptGroupElement;
// nsWrapperCache using nsWrapperCache::GetWrapper; using nsWrapperCache::GetWrapperPreserveColor; using nsWrapperCache::PreserveWrapper; virtual JSObject* WrapObject(JSContext* aCx,
JS::Handle<JSObject*> aGivenProto) override;
// Helpers for HTMLSelectElement /** * Insert an option * @param aOption the option to insert * @param aIndex the index to insert at
*/ void InsertOptionAt(mozilla::dom::HTMLOptionElement* aOption,
uint32_t aIndex) {
mElements.InsertElementAt(aIndex, aOption);
}
/** * Remove an option * @param aIndex the index of the option to remove
*/ void RemoveOptionAt(uint32_t aIndex) { mElements.RemoveElementAt(aIndex); }
/** * Get the option at the index * @param aIndex the index * @param aReturn the option returned [OUT]
*/
mozilla::dom::HTMLOptionElement* ItemAsOption(uint32_t aIndex) { return mElements.SafeElementAt(aIndex, nullptr);
}
/** * Clears out all options
*/ void Clear() { mElements.Clear(); }
/** * Append an option to end of array
*/ void AppendOption(mozilla::dom::HTMLOptionElement* aOption) {
mElements.AppendElement(aOption);
}
/** * Finds the index of a given option element. * If the option isn't part of the collection, return NS_ERROR_FAILURE * without setting aIndex. * * @param aOption the option to get the index of * @param aStartIndex the index to start looking at * @param aForward TRUE to look forward, FALSE to look backward * @return the option index
*/
nsresult GetOptionIndex(Element* aOption, int32_t aStartIndex, bool aForward,
int32_t* aIndex);
private: /** The list of options (holds strong references). This is infallible, so
* various members such as InsertOptionAt are also infallible. */
nsTArray<RefPtr<mozilla::dom::HTMLOptionElement> > mElements; /** The select element that contains this array */
RefPtr<HTMLSelectElement> mSelect;
};
} // namespace dom
} // namespace mozilla
#endif// mozilla_dom_HTMLOptionsCollection_h
¤ Dauer der Verarbeitung: 0.26 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.