Rumah  >  Soal Jawab  >  teks badan

javascript - Bagaimana untuk melaksanakan pembolehubah statik dalam js

<button type="button" onclick="func();">按钮</button>

var i = 0;
func(){
    i += 1;
    console.log(i)
}

Keperluan: Klik pembolehubah butang untuk meningkat sebanyak 1. Cari jalan terbaik untuk mencapainya.
Untuk menambah, terdapat banyak cara untuk mencapainya.

  1. Simpan terus ke dalam pembolehubah global - mencemarkan ruang nama global

  2. Gunakan tatasusunan global untuk menyimpan pembolehubah global apl semasa - tidak mematuhi seni bina semasa

  3. Penutupan - nampaknya tidak menyesuaikan diri dengan adegan semasa (gunakan onclick untuk mencetuskan fungsi)

  4. Dilabuhkan ke dalam elemen html - masih sangat rendah

  5. Menggunakan fungsi tanpa nama yang besar untuk memanjangkan hayat pembolehubah - tidak mematuhi seni bina semasa

天蓬老师天蓬老师2671 hari yang lalu798

membalas semua(5)saya akan balas

  • 某草草

    某草草2017-06-26 11:00:14

    Siapa kata penutupan tidak terpakai?

    var func = (function(){
    var i = 0;
    return function(){
        i++;
        console.log(i);
    }
    
    }());

    Atau anda boleh lakukan ini:

    var func = function(){
        func.i++;
        console.log(func.i);
    };
    func.i = 0;

    balas
    0
  • PHP中文网

    PHP中文网2017-06-26 11:00:14

    Disimpan dalam atribut nod dom

    <button data-click-number="0" type="button" id="incBtn" >按钮</button>
    $("#incBtn").on('click',function(){
     var preClickNumber=$(this).attr('data-click-number') ?: 1;
     $(this).attr('data-click-number',preClickNumber++);
    });

    balas
    0
  • 过去多啦不再A梦

    过去多啦不再A梦2017-06-26 11:00:14

    js tidak mempunyai pembolehubah statik. Terdapat hanya pembolehubah tempatan dan pembolehubah global.

    <button type="button" onclick="++i">按钮</button>
    
    var i = 0;

    balas
    0
  • 大家讲道理

    大家讲道理2017-06-26 11:00:14

    Tidak menggunakan let?

    balas
    0
  • 黄舟

    黄舟2017-06-26 11:00:14

    Penutupan sangat popular, saya cadangkan anda membaca beberapa buku tentang ungkapan fungsi JavaScript. Ini juga merupakan ciri utama JavaScript

    let click = (() => {
        var i = 0;
        return function() {
          i += 1;
          console.log(i)
        }
    })()

    balas
    0
  • Batalbalas