Pergunta

Esta linha de javascript é no Magento base de código em app/design/frontend/base/default/template/persistente/checkout/onepage/faturamento.phtml:

        $('billing-address-select') && billing.newAddress(!$('billing-address-select').value);

Aqui é a linha de contexto:

    <script type="text/javascript">
//<![CDATA[
var billing = new Billing('co-billing-form', 
                          '<?php echo $this->getUrl('checkout/onepage/getAddress') ?>address/', 
                          '<?php echo $this->getUrl('checkout/onepage/saveBilling') ?>');
var billingForm = new VarienForm('co-billing-form');

/*billingForm.setElementsRelation('billing:country_id', 
                                  'billing:region', 
                                  '<?php echo $this->getUrl('directory/json/childRegion') ?>', 
                                  '<?php echo $this->__('Select State/Province...') ?>');*/

$('billing-address-select') && billing.newAddress(!$('billing-address-select').value);

var billingRegionUpdater = new RegionUpdater('billing:country_id', 
                                             'billing:region', 
                                             'billing:region_id', 
                                             <?php echo $this->helper('directory')->getRegionJson() ?>, 
                                             undefined, 
                                             'billing:postcode');
if ($('onepage-guest-register-button')) {
    Event.observe($('onepage-guest-register-button'), 'click', function(event) {
        var billingRememberMe = $('co-billing-form').select('#remember-me-box');
        if (billingRememberMe.length > 0) {
            if ($('login:guest') && $('login:guest').checked) {
                billingRememberMe[0].hide();
            } else if ($('login:register') && ($('login:register').checked || $('login:register').type == 'hidden')) {
                billingRememberMe[0].show();
            }
        }
    });
}
//]]>
</script>        

Parece que a comparação de dois valores, mas não fazer nada com a comparação.Qual é o propósito disso?

Foi útil?

Solução

Eu fiz alguma pesquisa sobre isso.Eu pensei que o && foi puramente lógicos "e", mas ele também pode ser usado como um atalho para "se então".

Neste caso, se $('faturamento-endereço-seleccione') é verdade, o new function (em opcheckout.js) será chamado com "!$('faturamento-endereço-seleccione').valor" como um argumento.É uma forma estranha programaticamente mostrar ou ocultar o endereço do novo formulário na página de checkout.

Aqui está um Estouro de Pilha pergunta onde isso é explicado: https://stackoverflow.com/questions/3859433/an-explanation-of-shorthand-in-javascript

E uma boa explicação e vs &&:https://stackoverflow.com/questions/7310109/whats-the-difference-between-and-in-javascript

Licenciado em: CC-BY-SA com atribuição
Não afiliado a magento.stackexchange
scroll top