0

我很可能完全不理解 Zend 处理货币的方法。

我想要做的是有一个 Zend_Currency 对象,其中活动货币是 EURO,语言是英语(应用程序的语言环境是 en_GB)。Zend_Currency 连接到一个语言环境,如果创建一个带有英语语言环境的 Zend_Currency,我就不能有 EUR。

我也试过这个

$this->currency = new Zend_Currency(array('currency' => 'EUR'), "en_GB");

但如果我尝试

echo $this->currency->getSymbol(); // I get £

并且没有改变货币的方法。

4

3 回答 3

3

这有效:

$this->currency = new Zend_Currency('en_GB');
$this->currency->setFormat(array('currency' =>  'EUR', 'name' =>'EUR', 'symbol' => '€'));
于 2011-06-14T09:21:53.953 回答
2

我已经扩展Zend_Currency并覆盖了getName()andgetSymbol()方法,以便它们(就像Zend_Currency我们不想要的语言环境更改时一样......)Zend_Locale_Data每次我发出请求时都返回“新鲜”数据。

在下面的示例类中,您可以创建一个实例Default_Model_Currency()并将“货币”选项设置为任何有效货币(例如欧元、美元等),同时保持相同的语言环境。

<?php

/*
* Currency class extends Zend_Currency with exchange
* functionality using the Exchange_Service
*
* @author HF Bonnet
*/
class Default_Model_Currency extends Zend_Currency
{
    /*
    * Precision to round currency values with, the
    * default precision is 0
    */
    private $_precision = 0;




    /*
    * Set the currency's precision
    *
    * @attribute int $precision
    * @return Default_Model_Currency
    */
    public function setPrecision($precision)
    {
        $validator = new Zend_Validator_Digits();
        if ($validator->isValid($precision))
            $this->_precision = $precision;

        return $this;
    }



    /*
    * Becouse of problems with zend_currency I've choosen
    * to override __toString
    */
    public function __toString()
    {
        return sprintf(
            '%s %s',
            $this->getShortName(),
            $this->getValue()
        );
    }



    /*
    * Get the full name from a currency, this method is overwitten
    * to support the changing of currency without changing the locale
    *
    * @param string $currency (Optional) Currency name
    * @param string|Zend_Locale $locale
    * @return string $name
    */
    public function getName($currency = null, $locale = null)
    {
        return Zend_Locale_Data::getContent(
            null, 
            'nametocurrency', 
            $this->getShortName()
        );
    }



    /*
    * Get the full name from a currency, this method is overwitten
    * to support the changing of a locale
    *       
    * @param string $currency (Optional) Currency name
    * @param string|Zend_Locale $locale
    * @return string $name
    */
    public function getSymbol($currency = null, $locale = null)
    {
        return Zend_Locale_Data::getContent(
            null, 
            'currencysymbol', 
            $this->getShortName()
        );
    }



    /*
    * Get the localized value from the currency
    *
    * @return string $value
    */
    public function getLocalizedValue()
    {
        return Zend_Locale_Format::toNumber(
            parent::getValue(),
            array(
                'precision' => $this->_precision,
                'locale' => $this->getLocale()
            )
        );
    }



    /*
    * Get the default valuta. First checks in the Zend_Registry
    * for the default valuta, if not found it is fetched from the
    * database.
    * 
    * @return string $defaultCurrency
    */
    public function getDefaultValuta()
    {
        $currency = Zend_Registry::get('currency');

        if (!isset($currency['default'])):
            $className = Zend_Registry::get('prefix')->services . 'Registry';
            $currency['default'] = $className::getInstance()
                                             ->getDb('currencyValuta')
                                             ->getDefaultValuta()
                                             ->getIso();
            Zend_Registry::set(
                'currency', $currency
            );
        endif;

        return $currency['default'];
    }



    /*
    * Exchanges the currency using the rates found in the
    * exchange service.
    *
    * @attribute string $to
    * @return Default_Model_Currency
    */
    public function exchange($to)
    {
        if ($to === $this->getShortName())
            return $this;

        $currencyTo = new Default_Model_Currency(
            array(
                'value' => 0,
                'currency' => $to,
                'precision' => $this->_precision
            )
        );

        // Set the exchange service
        $currencyTo->setService(
            $this->getExchangeService()
        );

        return $currencyTo->add($this);
    }



    /*
    * Get an Default_Model_Settings instance
    * 
    * @return Default_Model_Settings 
    */
    public function getExchangeService()
    {
        $className = Zend_Registry::get('prefix')->services . 'Exchange';
        return $className::getInstance();
    }

}
于 2012-05-17T16:58:25.783 回答
-2

这似乎有效:-

$currency = new Zend_Currency();
$currency->setFormat(array('currency' => 'EUR', 'symbol' => '€'));

您可以传递 getFormat() 一个数组来设置这样的选项。 http://framework.zend.com/manual/en/zend.currency.options.html

于 2011-06-10T16:18:11.737 回答