Domanda

Questa riga di JavaScript è nel codice di base Magento in app / design / frontend / base / predefinita / modello / persistente / checkout / onepage / fatturazione.phtml:

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

Ecco la linea in contesto:

    <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>        
.

Sembra che stia confrontando due valori ma non facendo nulla con il confronto.Qual è lo scopo di esso?

È stato utile?

Soluzione

Ho fatto qualche ricerca su questo.Pensavo che il && sia stato puramente logico "e", ma può anche essere usato come una scorciatoia per "se poi".

In questo caso, se $ ('fatturazione-indirizzo-select') è vera, la funzione newaddress (in opcheckout.js) sarà chiamata con "! $ ('fatturazione-indirizzo-select'). Valore" comeun argomento.È un modo strano per mostrare a livello di programmazione o nascondere il nuovo modulo di indirizzo su una pagina checkout.

Ecco una domanda di overflow stack dove questo è spiegato: https://stackoverflow.com/ Domande / 3859433 / An-spiegazione-of-shirthand-in-javascript

E una buona spiegazione di & vs &&: https://stackoverflow.com/questions/7310109/Quals-the-difference-tra-and-in-javascript

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a magento.stackexchange
scroll top