當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ET::trigger方法代碼示例

本文整理匯總了PHP中ET::trigger方法的典型用法代碼示例。如果您正苦於以下問題:PHP ET::trigger方法的具體用法?PHP ET::trigger怎麽用?PHP ET::trigger使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在ET的用法示例。


在下文中一共展示了ET::trigger方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: trigger

 /**
  * Triggers an event, returning an array of return values from event handlers.
  *
  * Two events will actually be triggered: one prefixed with the name of this class,
  * one not. For example, if an instance of ETPluggable calls $this->trigger("eventName"),
  * both "ETPluggable_eventName" and "eventName" events will be triggered.
  *
  * The event handlers are called with $this as the first argument, and optionally any extra
  * $parameters. The return values from each handler are collected and then returned in an array.
  *
  * @param string $event The name of the event.
  * @param array $parameters An array of extra parameters to pass to the event handlers.
  */
 public function trigger($event, $parameters = array())
 {
     // Add the instance of this class to the parameters.
     array_unshift($parameters, $this);
     $return = array();
     // If we have a class name to use, trigger an event with that as the prefix.
     if ($this->className) {
         $return = ET::trigger($this->className . "_" . $event, $parameters);
     }
     // Trigger the event globally.
     $return = array_merge($return, ET::trigger($event, $parameters));
     return $return;
 }
開發者ID:19eighties,項目名稱:esoTalk,代碼行數:26,代碼來源:ETPluggable.class.php

示例2: dispatch

 /**
  * Dispatch a request to $method, passing along $arguments.
  *
  * @param string $method The name of the controller method.
  * @param array $arguments An array of arguments to pass to the method.
  * @return void
  */
 public function dispatch($method, $arguments)
 {
     // Create an array of arguments where the first item is $this.
     $eventArguments = array_merge(array(&$this), $arguments);
     $eventName = $this->className . "_" . $method;
     // Trigger a "before" event for this method.
     ET::trigger($eventName . "_before", $eventArguments);
     // Go through plugins and look for a handler for this controller/method.
     $called = false;
     foreach (ET::$plugins as $plugin) {
         $actionName = "action_" . $eventName;
         if (method_exists($plugin, $actionName)) {
             call_user_func_array(array($plugin, $actionName), $eventArguments);
             $called = true;
             break;
         }
     }
     // If one wasn't found, call the method on $this.
     if (!$called) {
         call_user_func_array(array($this, "action_" . $method), $arguments);
     }
     // Trigger an "after" event for this method.
     ET::trigger($eventName . "_after", $eventArguments);
 }
開發者ID:davchezt,項目名稱:fireside,代碼行數:31,代碼來源:ETController.class.php

示例3: slug

/**
 * Create a slug for use in URLs from a given string. Any non-alphanumeric characters will be converted to "-".
 *
 * @param string $string The string to convert.
 * @return string The slug.
 *
 * @package esoTalk
 */
function slug($string)
{
    // If there are any characters other than basic alphanumeric, space, punctuation, then we need to attempt transliteration.
    if (preg_match("/[^ -]/", $string)) {
        // Thanks to krakos for this code! http://esotalk.org/forum/582-unicode-in-usernames-and-url-s
        if (function_exists('transliterator_transliterate')) {
            // Unicode decomposition rules states that these cannot be decomposed, hence
            // we have to deal with them manually. Note: even though “scharfes s” is commonly
            // transliterated as “sz”, in this context “ss” is preferred, as it's the most popular
            // method among German speakers.
            $src = array('œ', 'æ', 'đ', 'ø', 'ł', 'ß', 'Œ', 'Æ', 'Đ', 'Ø', 'Ł');
            $dst = array('oe', 'ae', 'd', 'o', 'l', 'ss', 'OE', 'AE', 'D', 'O', 'L');
            $string = str_replace($src, $dst, $string);
            // Using transliterator to get rid of accents and convert non-Latin to Latin
            $string = transliterator_transliterate("Any-Latin; NFD; [:Nonspacing Mark:] Remove; NFC; [:Punctuation:] Remove; Lower();", $string);
        } else {
            // A fallback to old method.
            // Convert special Latin letters and other characters to HTML entities.
            $string = htmlentities($string, ENT_NOQUOTES, "UTF-8");
            // With those HTML entities, either convert them back to a normal letter, or remove them.
            $string = preg_replace(array("/&([a-z]{1,2})(acute|cedil|circ|grave|lig|orn|ring|slash|th|tilde|uml|caron);/i", "/&[^;]{2,6};/"), array("\$1", " "), $string);
        }
    }
    // Allow plugins to alter the slug.
    ET::trigger("slug", array(&$string));
    // Now replace non-alphanumeric characters with a hyphen, and remove multiple hyphens.
    $slug = str_replace(' ', '-', trim(preg_replace('~[^\\pL\\d]+~u', ' ', mb_strtolower($string, "UTF-8"))));
    return mb_substr($slug, 0, 63, "UTF-8");
}
開發者ID:xiaolvmu,項目名稱:Techllage,代碼行數:37,代碼來源:functions.general.php

示例4: sendEmail

/**
 * Send an email with proper headers.
 *
 * @param string $to The address to send the email to.
 * @param string $subject The subject of the email.
 * @param string $body The body of the email.
 * @return bool Whether or not the mailing succeeded.
 */
function sendEmail($to, $subject, $body)
{
    if ($return = ET::trigger("sendEmailBefore", array(&$to, &$subject, &$body)) and !empty($return)) {
        return reset($return);
    }
    $headers = "From: " . sanitizeForHTTP(C("esoTalk.forumTitle") . " <" . C("esoTalk.emailFrom") . ">") . "\r\n" . 'X-Mailer: esoTalk' . "\r\n" . 'MIME-Version: 1.0' . "\r\n" . "Content-Type: text/plain; charset=" . T("charset") . "";
    return mail($to, $subject, $body, $headers);
}
開發者ID:nowaym,項目名稱:esoTalk,代碼行數:16,代碼來源:functions.general.php

示例5: sendEmail

/**
 * Send an email with proper headers.
 *
 * @param string $to The address to send the email to.
 * @param string $subject The subject of the email.
 * @param string $body The body of the email.
 * @return bool Whether or not the mailing succeeded.
 *
 * @package esoTalk
 */
function sendEmail($to, $subject, $body)
{
    $phpmailer = PATH_LIBRARY . '/vendor/class.phpmailer.php';
    require_once $phpmailer;
    $mail = new PHPMailer(true);
    if ($return = ET::trigger("sendEmailBefore", array($mail, &$to, &$subject, &$body)) and !empty($return)) {
        return reset($return);
    }
    $mail->IsHTML(true);
    $mail->AddAddress($to);
    $mail->SetFrom(C("esoTalk.emailFrom"), sanitizeForHTTP(C("esoTalk.forumTitle")));
    $mail->Subject = sanitizeForHTTP($subject);
    $mail->Body = $body;
    return $mail->Send();
}
開發者ID:AlexandrST,項目名稱:esoTalk,代碼行數:25,代碼來源:functions.general.php


注:本文中的ET::trigger方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。