mirror of
https://github.com/PuerkitoBio/goquery
synced 2025-10-07 17:51:16 +08:00
73 lines
2.1 KiB
Go
73 lines
2.1 KiB
Go
package goquery
|
|
|
|
import (
|
|
"regexp"
|
|
"strings"
|
|
|
|
"code.google.com/p/cascadia"
|
|
"code.google.com/p/go.net/html"
|
|
)
|
|
|
|
var rxClassTrim = regexp.MustCompile("[\t\r\n]")
|
|
|
|
// Is checks the current matched set of elements against a selector and
|
|
// returns true if at least one of these elements matches.
|
|
func (s *Selection) Is(selector string) bool {
|
|
if len(s.Nodes) > 0 {
|
|
// Attempt a match with the selector
|
|
cs := cascadia.MustCompile(selector)
|
|
if len(s.Nodes) == 1 {
|
|
return cs.Match(s.Nodes[0])
|
|
} else {
|
|
return len(cs.Filter(s.Nodes)) > 0
|
|
}
|
|
}
|
|
|
|
return false
|
|
}
|
|
|
|
// IsFunction checks the current matched set of elements against a predicate and
|
|
// returns true if at least one of these elements matches.
|
|
func (s *Selection) IsFunction(f func(int, *Selection) bool) bool {
|
|
return s.FilterFunction(f).Length() > 0
|
|
}
|
|
|
|
// IsSelection checks the current matched set of elements against a Selection object
|
|
// and returns true if at least one of these elements matches.
|
|
func (s *Selection) IsSelection(sel *Selection) bool {
|
|
return s.FilterSelection(sel).Length() > 0
|
|
}
|
|
|
|
// IsNodes checks the current matched set of elements against the specified nodes
|
|
// and returns true if at least one of these elements matches.
|
|
func (s *Selection) IsNodes(nodes ...*html.Node) bool {
|
|
return s.FilterNodes(nodes...).Length() > 0
|
|
}
|
|
|
|
// HasClass determines whether any of the matched elements are assigned the
|
|
// given class.
|
|
func (s *Selection) HasClass(class string) bool {
|
|
class = " " + class + " "
|
|
for _, n := range s.Nodes {
|
|
// Applies only to element nodes
|
|
if n.Type == html.ElementNode {
|
|
if elClass, ok := getAttributeValue("class", n); ok {
|
|
elClass = rxClassTrim.ReplaceAllString(" "+elClass+" ", " ")
|
|
if strings.Index(elClass, class) > -1 {
|
|
return true
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
// Contains returns true if the specified Node is within,
|
|
// at any depth, one of the nodes in the Selection object.
|
|
// It is NOT inclusive, to behave like jQuery's implementation, and
|
|
// unlike Javascript's .contains, so if the contained
|
|
// node is itself in the selection, it returns false.
|
|
func (s *Selection) Contains(n *html.Node) bool {
|
|
return sliceContains(s.Nodes, n)
|
|
}
|