Rumah >hujung hadapan web >tutorial js >Menyetempatkan tali JavaScript dalam rangka PHP MVC

Menyetempatkan tali JavaScript dalam rangka PHP MVC

尊渡假赌尊渡假赌尊渡假赌
尊渡假赌尊渡假赌尊渡假赌asal
2025-02-22 10:18:10634semak imbas

kaedah penyetempatan rentetan JavaScript yang cekap dalam rangka PHP MVC

Localizing JavaScript Strings in a PHP MVC Framework

Artikel ini akan menunjukkan bagaimana untuk menyetempatkan rentetan JavaScript dalam rangka PHP. Anda boleh memuat turun pelaksanaan kerja tutorial ini dari sini.

Terdapat beberapa cara untuk melokalkan rentetan JavaScript dalam persekitaran PHP. Secara teknikal, fail JavaScript boleh disalin dan dinamakan mengikut bahasa sasaran dan versi yang diperlukan dimuatkan setiap kali pengguna memilih bahasa baru di laman web. Tetapi ia adalah satu cara untuk menjadi sukar untuk menyebutnya amalan terbaik, walaupun ia "berfungsi".

Kelemahan utama pendekatan ini ialah setiap kali anda perlu mengubah suai kod JavaScript, anda mesti melakukan pengubahsuaian untuk setiap bahasa. Ini bukan sahaja terdedah kepada kesilapan, tetapi juga meningkatkan beban kerja yang tidak perlu.

cara lain ialah memanggil rentetan literal secara langsung melalui pembolehubah PHP yang tertanam dalam kod JavaScript, tetapi ia bergantung kepada seni bina kerangka anda dan tidak selalu tersedia pilihan.

Jadi saya akan menunjukkan kepada anda kaedah yang pasti berkesan dan mudah dijaga.

Ingat bahawa anda boleh memuat turun contoh yang boleh dilancarkan dari sini.

mari kita mulakan ...

Dalam contoh yang datang dengan tutorial ini, saya menyediakan butang yang mencetuskan fungsi JavaScript bernama Trigger_MSG ():

<code class="language-php">echo '';</code>
fungsi trigger_msg () terletak di /public/js/main.js:

<code class="language-javascript">function trigger_msg(){
    return alert(translate(LOCALIZATION.here_is_how_it_works));
    }</code>
    kami memanggil fungsi Terjemahan () yang terletak di /languages/translate.js dan lulus nama elemen yang dikehendaki yang terkandung dalam array bernama lokalisasi sebagai parameter.
  • Kami menggunakan sintaks terjemahan (name_of_language_array.name_of_element, extra_parameter1, extra_parameter2, dll ...), dan hanya gunakan koma untuk memisahkan parameter tambahan.
  • Jika parameter tertutup dalam petikan, parameter tentu saja boleh menjadi teks.
Sebelum kita menyelam lebih mendalam ke dalam fungsi Terjemahan (), inilah array penyetempatan seperti di /languages/current_language/js/current_language.js:

<code class="language-javascript">var LOCALIZATION = {
    here_is_how_it_works :  'Voici comment cela fonctionne.\nAppuyez sur le bouton suivant afin de voir comment ça se passe avec des paramètres.',
    who_does_not_know_are_and_that_the_sky_is :  'Qui ne sait pas que %s x %s font %s,\net que le ciel est %s?',
    blue : 'bleu'
  };</code>
Dalam definisi elemen array kami, anda dapat melihat bahawa "%s" digunakan, yang merupakan ungkapan yang kami gunakan untuk menjimatkan parameter tambahan. Walau bagaimanapun, kami akan membincangkannya kemudian. Ambil perhatian bahawa jika anda menggunakan dialog tersuai, anda boleh memasukkan tag gaya HTML ke dalam definisi elemen array, seperti

, dan lain -lain, dan ia akan berfungsi dengan baik.

sudah tiba masanya untuk mengikuti fungsi terjemahan () kami:

<code class="language-javascript">(function () {

    if (!window.translate){

      window.translate = function(){
        var html = [ ]; 
        var arguments = arguments;
        var string = arguments[0];

        var objIndex = 0;
        var reg = /%s/;
        var parts = [ ];

        for ( var m = reg.exec(string); m; m = reg.exec(string) ) {  
          parts.push(string.substr(0, m.index));
          parts.push("%s");
          string = string.substr( m.index+m[0].length );
        }
        parts.push(string);

        for (var i = 0; i < parts.length; ++i){
            var part = parts[i];
            if (part && part == "%s"){
              var object = arguments[++objIndex];
              if (object == undefined) {
                html.push("%s");
              }else{
                html.push(object);
              };
            }else{
              html.push(part);
            }            
        }

        return html.join('');
      }
    };
  })();</code>
Fungsi berikut membentuk teras penyelesaian penyetempatan JavaScript kami.

Pada dasarnya, dalam rentetan yang dinamakan pembolehubah, kami menyimpan parameter yang ditangkap dari fungsi trigger_msg (), menghirupnya pada yang pertama untuk gelung, menapis mereka menggunakan ungkapan biasa yang disimpan dalam pembolehubah yang dinamakan Reg, dan tolak bahagian hasilnya ke dalam Arahan yang dipanggil bahagian []. Kami kemudian mengulangi bahagian -bahagian ini ke dalam array yang dipanggil HTML [], dan fungsi kami akan mengembalikan array itu.

Pembolehubah yang dinamakan Reg memegang ungkapan biasa '/ %s/', %s adalah sintaks yang kita pilih seperti di atas untuk menentukan parameter.

Fungsi trigger_msg_with_params () dalam

/public/js/main.js menunjukkan cara menggunakan parameter apabila menyusun rentetan. Sebenarnya, dalam sistem, kadang -kadang rentetan literal yang perlu diterjemahkan mungkin mengandungi nilai yang bergantung kepada input pengguna, dan fungsi ini menjadi sangat berguna dengan membenarkan kod digunakan semula dengan kerap:

<code class="language-php">echo '';</code>

anda dapat melihat setiap parameter yang ditentukan, seperti VAR PARAM1, atau ia juga boleh menjadi parameter yang diluluskan kepada panggilan fungsi. Parameter yang ditakrifkan juga boleh menjadi panggilan sebenar fungsi Terjemahan (). Semua ini membuktikan sangat berguna lagi.

Ini semua. Sistem ini mewakili cara yang cekap dan boleh dipercayai untuk menterjemahkan rentetan JavaScript anda di seluruh rangka PHP anda dan membolehkan tahap fleksibiliti yang tinggi.

anda dialu -alukan untuk meninggalkan komen atau soalan anda. Tinggal untuk lebih banyak tutorial.

Arahan pengubahsuaian: Teks asal telah diselaraskan dan penggantian perbendaharaan kata untuk menjadikannya lebih lancar dan lebih semula jadi, dan teks asal tetap tidak berubah. Juga menetapkan potensi isu keserasian pelayar IE dalam coretan kod (m[0][0] boleh kembali undefined IE). Gambar yang tinggal tetap sama.

Atas ialah kandungan terperinci Menyetempatkan tali JavaScript dalam rangka PHP MVC. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn