开发者

drupal: getting nodeautoterm node ids from taxonomy ids

开发者 https://www.devze.com 2022-12-19 07:14 出处:网络
I\'m using drupal\'s NAT module and need to get the nid from the term id. Here\'s what I tried: foreach ( (array)nat_get_nids($termid) as $natid ) {

I'm using drupal's NAT module and need to get the nid from the term id.

Here's what I tried:

foreach ( (array)nat_get_nids($termid) as $natid ) {
    $NatName = $natid->name;
}
print $natid;

This does not work.

Node auto term's get nid function is like this:

function nat_get_nids($tids, $get_nodes = FALSE) {
  static $nid_cache = NULL;
  static $node_cache = NULL;

  $return = array();

  // Keep processing to a minimum for empty tid arrays.
  if (!empty($tids)) {
    // Sort tid array to ensure that the cache_string never suffers from order
    // issues.
    sort($tids);
    $cache_string = implode('+', $tids);
    if ($get_nodes) {
      if (isset($node_cache[$cache_string])) {
        return $node_cache[$cache_string];
      }
      elseif (isset($nid_cache[$cache_string])) {
        // If the nid cache stores the same string, node_load() each nid and
        // return them.
        $return = array();
        foreach (array_keys($nid_cache[$cache_string]) as $nid) {
          $return[$nid] = node_load($nid);
        }
        $node_cache[$cache_string] = $return;

        return $return;
      }
    }
    else {
      if (isset($nid_cache[$cache_string])) {
        return $nid_cache[$cache_string];
      }
      elseif (isset($node_cache[$cache_string])) {
        // If the node cache stores the same string, retrieve only the nids and
        // return them.
        foreach ($node_cache[$cache_string] as $nid => $node) {
          $return[$nid] = $node->name;
        }
        // Cache extracted results.
        $nid_cache[$cache_string] = $return;

        return $return;
      }
    }

    // Results have not been cached.
    $tids = implode(', ', $tids);
    $result = db_query("SELECT n.nid, t.name FROM {nat} n INNER JOIN {term_data} t USING (tid) WHERE n.tid IN (". db_placeholders($tids) .")", $tids);
    while ($node = db_fetch_object($result)) {
      if ($get_nodes) {
        $return[$node->nid] = node_load($node->nid);
      }
      else {
        $return[$node->nid] = $node-开发者_JS百科>name;
      }
    }

    if ($get_nodes) {
      $node_cache[$cache_string] = $return;
    }
    else {
      $nid_cache[$cache_string] = $return;
    }
  }

  return $return;
}

Thanks in advance!

Edit: Try based on the first answer:

foreach (nat_get_nids($termid) as $nid => $node_name) {

}

print $node_name;


It looks like nat_get_nids is returning an associative array, so your for loop should look like

foreach (nat_get_nids($termid) as $nid => $node_name) {
  ...
}


$nids = nat_get_nids(array($termid));
0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号