| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317 | 
							- /**
 
-  * Methods for getting and modifying attributes.
 
-  *
 
-  * @module cheerio/attributes
 
-  */
 
- import type { Node, Element } from 'domhandler';
 
- import type { Cheerio } from '../cheerio';
 
- /**
 
-  * Method for getting attributes. Gets the attribute value for only the first
 
-  * element in the matched set.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('ul').attr('id');
 
-  * //=> fruits
 
-  * ```
 
-  *
 
-  * @param name - Name of the attribute.
 
-  * @returns The attribute's value.
 
-  * @see {@link https://api.jquery.com/attr/}
 
-  */
 
- export declare function attr<T extends Node>(this: Cheerio<T>, name: string): string | undefined;
 
- /**
 
-  * Method for getting all attributes and their values of the first element in
 
-  * the matched set.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('ul').attr();
 
-  * //=> { id: 'fruits' }
 
-  * ```
 
-  *
 
-  * @returns The attribute's values.
 
-  * @see {@link https://api.jquery.com/attr/}
 
-  */
 
- export declare function attr<T extends Node>(this: Cheerio<T>): Record<string, string>;
 
- /**
 
-  * Method for setting attributes. Sets the attribute value for only the first
 
-  * element in the matched set. If you set an attribute's value to `null`, you
 
-  * remove that attribute. You may also pass a `map` and `function`.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('.apple').attr('id', 'favorite').html();
 
-  * //=> <li class="apple" id="favorite">Apple</li>
 
-  * ```
 
-  *
 
-  * @param name - Name of the attribute.
 
-  * @param value - The new value of the attribute.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/attr/}
 
-  */
 
- export declare function attr<T extends Node>(this: Cheerio<T>, name: string, value?: string | null | ((this: Element, i: number, attrib: string) => string | null)): Cheerio<T>;
 
- /**
 
-  * Method for setting multiple attributes at once. Sets the attribute value for
 
-  * only the first element in the matched set. If you set an attribute's value to
 
-  * `null`, you remove that attribute.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('.apple').attr({ id: 'favorite' }).html();
 
-  * //=> <li class="apple" id="favorite">Apple</li>
 
-  * ```
 
-  *
 
-  * @param values - Map of attribute names and values.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/attr/}
 
-  */
 
- export declare function attr<T extends Node>(this: Cheerio<T>, values: Record<string, string | null>): Cheerio<T>;
 
- interface StyleProp {
 
-     length: number;
 
-     [key: string]: string | number;
 
-     [index: number]: string;
 
- }
 
- /**
 
-  * Method for getting and setting properties. Gets the property value for only
 
-  * the first element in the matched set.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('input[type="checkbox"]').prop('checked');
 
-  * //=> false
 
-  *
 
-  * $('input[type="checkbox"]').prop('checked', true).val();
 
-  * //=> ok
 
-  * ```
 
-  *
 
-  * @param name - Name of the property.
 
-  * @param value - If specified set the property to this.
 
-  * @returns If `value` is specified the instance itself, otherwise the prop's value.
 
-  * @see {@link https://api.jquery.com/prop/}
 
-  */
 
- export declare function prop<T extends Node>(this: Cheerio<T>, name: 'tagName' | 'nodeName'): T extends Element ? string : undefined;
 
- export declare function prop<T extends Node>(this: Cheerio<T>, name: 'innerHTML' | 'outerHTML'): string | null;
 
- export declare function prop<T extends Node>(this: Cheerio<T>, name: 'style'): StyleProp;
 
- export declare function prop<T extends Node, K extends keyof Element>(this: Cheerio<T>, name: K): Element[K];
 
- export declare function prop<T extends Node, K extends keyof Element>(this: Cheerio<T>, name: K, value: Element[K] | ((this: Element, i: number, prop: K) => Element[keyof Element])): Cheerio<T>;
 
- export declare function prop<T extends Node>(this: Cheerio<T>, name: Record<string, string | Element[keyof Element] | boolean>): Cheerio<T>;
 
- export declare function prop<T extends Node>(this: Cheerio<T>, name: string, value: string | boolean | null | ((this: Element, i: number, prop: string) => string | boolean)): Cheerio<T>;
 
- export declare function prop<T extends Node>(this: Cheerio<T>, name: string): string;
 
- /**
 
-  * Method for getting data attributes, for only the first element in the matched set.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('<div data-apple-color="red"></div>').data('apple-color');
 
-  * //=> 'red'
 
-  * ```
 
-  *
 
-  * @param name - Name of the data attribute.
 
-  * @returns The data attribute's value.
 
-  * @see {@link https://api.jquery.com/data/}
 
-  */
 
- export declare function data<T extends Node>(this: Cheerio<T>, name: string): unknown | undefined;
 
- /**
 
-  * Method for getting all of an element's data attributes, for only the first
 
-  * element in the matched set.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('<div data-apple-color="red"></div>').data();
 
-  * //=> { appleColor: 'red' }
 
-  * ```
 
-  *
 
-  * @returns The data attribute's values.
 
-  * @see {@link https://api.jquery.com/data/}
 
-  */
 
- export declare function data<T extends Node>(this: Cheerio<T>): Record<string, unknown>;
 
- /**
 
-  * Method for setting data attributes, for only the first element in the matched set.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * const apple = $('.apple').data('kind', 'mac');
 
-  *
 
-  * apple.data('kind');
 
-  * //=> 'mac'
 
-  * ```
 
-  *
 
-  * @param name - Name of the data attribute.
 
-  * @param value - The new value.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/data/}
 
-  */
 
- export declare function data<T extends Node>(this: Cheerio<T>, name: string, value: unknown): Cheerio<T>;
 
- /**
 
-  * Method for setting multiple data attributes at once, for only the first
 
-  * element in the matched set.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * const apple = $('.apple').data({ kind: 'mac' });
 
-  *
 
-  * apple.data('kind');
 
-  * //=> 'mac'
 
-  * ```
 
-  *
 
-  * @param values - Map of names to values.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/data/}
 
-  */
 
- export declare function data<T extends Node>(this: Cheerio<T>, values: Record<string, unknown>): Cheerio<T>;
 
- /**
 
-  * Method for getting the value of input, select, and textarea. Note: Support
 
-  * for `map`, and `function` has not been added yet.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('input[type="text"]').val();
 
-  * //=> input_text
 
-  * ```
 
-  *
 
-  * @returns The value.
 
-  * @see {@link https://api.jquery.com/val/}
 
-  */
 
- export declare function val<T extends Node>(this: Cheerio<T>): string | undefined | string[];
 
- /**
 
-  * Method for setting the value of input, select, and textarea. Note: Support
 
-  * for `map`, and `function` has not been added yet.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('input[type="text"]').val('test').html();
 
-  * //=> <input type="text" value="test"/>
 
-  * ```
 
-  *
 
-  * @param value - The new value.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/val/}
 
-  */
 
- export declare function val<T extends Node>(this: Cheerio<T>, value: string | string[]): Cheerio<T>;
 
- /**
 
-  * Method for removing attributes by `name`.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('.pear').removeAttr('class').html();
 
-  * //=> <li>Pear</li>
 
-  *
 
-  * $('.apple').attr('id', 'favorite');
 
-  * $('.apple').removeAttr('id class').html();
 
-  * //=> <li>Apple</li>
 
-  * ```
 
-  *
 
-  * @param name - Name of the attribute.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/removeAttr/}
 
-  */
 
- export declare function removeAttr<T extends Node>(this: Cheerio<T>, name: string): Cheerio<T>;
 
- /**
 
-  * Check to see if *any* of the matched elements have the given `className`.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('.pear').hasClass('pear');
 
-  * //=> true
 
-  *
 
-  * $('apple').hasClass('fruit');
 
-  * //=> false
 
-  *
 
-  * $('li').hasClass('pear');
 
-  * //=> true
 
-  * ```
 
-  *
 
-  * @param className - Name of the class.
 
-  * @returns Indicates if an element has the given `className`.
 
-  * @see {@link https://api.jquery.com/hasClass/}
 
-  */
 
- export declare function hasClass<T extends Node>(this: Cheerio<T>, className: string): boolean;
 
- /**
 
-  * Adds class(es) to all of the matched elements. Also accepts a `function`.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('.pear').addClass('fruit').html();
 
-  * //=> <li class="pear fruit">Pear</li>
 
-  *
 
-  * $('.apple').addClass('fruit red').html();
 
-  * //=> <li class="apple fruit red">Apple</li>
 
-  * ```
 
-  *
 
-  * @param value - Name of new class.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/addClass/}
 
-  */
 
- export declare function addClass<T extends Node, R extends ArrayLike<T>>(this: R, value?: string | ((this: Element, i: number, className: string) => string | undefined)): R;
 
- /**
 
-  * Removes one or more space-separated classes from the selected elements. If no
 
-  * `className` is defined, all classes will be removed. Also accepts a `function`.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('.pear').removeClass('pear').html();
 
-  * //=> <li class="">Pear</li>
 
-  *
 
-  * $('.apple').addClass('red').removeClass().html();
 
-  * //=> <li class="">Apple</li>
 
-  * ```
 
-  *
 
-  * @param name - Name of the class. If not specified, removes all elements.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/removeClass/}
 
-  */
 
- export declare function removeClass<T extends Node, R extends ArrayLike<T>>(this: R, name?: string | ((this: Element, i: number, className: string) => string | undefined)): R;
 
- /**
 
-  * Add or remove class(es) from the matched elements, depending on either the
 
-  * class's presence or the value of the switch argument. Also accepts a `function`.
 
-  *
 
-  * @category Attributes
 
-  * @example
 
-  *
 
-  * ```js
 
-  * $('.apple.green').toggleClass('fruit green red').html();
 
-  * //=> <li class="apple fruit red">Apple</li>
 
-  *
 
-  * $('.apple.green').toggleClass('fruit green red', true).html();
 
-  * //=> <li class="apple green fruit red">Apple</li>
 
-  * ```
 
-  *
 
-  * @param value - Name of the class. Can also be a function.
 
-  * @param stateVal - If specified the state of the class.
 
-  * @returns The instance itself.
 
-  * @see {@link https://api.jquery.com/toggleClass/}
 
-  */
 
- export declare function toggleClass<T extends Node, R extends ArrayLike<T>>(this: R, value?: string | ((this: Element, i: number, className: string, stateVal?: boolean) => string), stateVal?: boolean): R;
 
- export {};
 
- //# sourceMappingURL=attributes.d.ts.map
 
 
  |