Penjelasan terperinci tentang penggunaan praktikal susun atur jadual HTML_HTML/Xhtml_Pengeluaran halaman web

WBOY
Lepaskan: 2016-05-16 16:36:18
asal
1745 orang telah melayarinya

Bilakah borang akan digunakan

Pada masa kini, jadual biasanya tidak lagi digunakan untuk reka letak keseluruhan halaman web. Walau bagaimanapun, apabila berhadapan dengan reka bentuk khusus tertentu, seperti input borang dan pembentangan data, jadual mungkin merupakan pilihan yang paling sesuai.

Kesan intuitif jadual ialah ia terdiri daripada berbilang sel yang disusun dengan kemas, dan baris serta lajur dapat dilihat dengan jelas. Ini boleh dikaitkan dengan Excel Berdasarkan status Excel dalam pemprosesan data dan statistik, kita boleh memahami maksud jadual pada halaman web.

Ringkasnya, apabila anda secara intuitif dapat merasakan berbilang elemen disusun dalam baris dan lajur, menggunakan jadual akan menjadikannya lebih mudah untuk anda. Seperti contoh borang permohonan dalam caniuse.com:
2015728173924594.png (470×175)

Pengiraan susun atur jadual

Menggunakan jadual adalah sangat mudah, tetapi kadangkala keadaan akhir yang dibentangkan oleh jadual untuk setiap grid mungkin tidak seperti yang anda mahukan. Contohnya, jika sesetengah grid mempunyai pemisah baris, keseluruhan jadual akan kelihatan sangat tidak sedap dipandang kerana pemisah baris. Terutamanya untuk jadual yang digunakan untuk pembentangan data, peruntukan lebar adalah topik yang sangat penting Anda mungkin perlu mengira dengan teliti jumlah lebar jadual untuk data yang mungkin dikemukakan oleh setiap lajur grid.

Ini kerana jadual mempunyai ciri tersendiri dalam susun atur Ia akan mengikut prinsip tertentu dan menentukan susun aturnya yang sebenar melalui pengiraan. Seterusnya, artikel ini menggunakan contoh ujian jadual sebenar untuk meneroka cara jadual mengira reka letaknya sendiri.
Pernyataan Awal

Artikel ini hanya menumpukan pada kaedah yang paling biasa untuk menggunakan jadual, dan tidak menyenaraikan semua situasi. Pelayar yang berbeza mempunyai tafsiran yang berbeza bagi beberapa konsep jadual, tetapi pengiraan susun atur pada dasarnya adalah sama (jika terdapat perbezaan, ia akan disebut secara berasingan).

Borang ujian yang digunakan seterusnya akan kelihatan seperti ini (kandungan diambil dari Zero Track):
2015728173942365.jpg (535×183)

Pada masa yang sama, jadual akan menetapkan sempadan-collapse:collapse; dan jarak sempadan:0;. Ini juga merupakan cara yang paling biasa untuk menggunakan jadual Normalize.css menggunakan bahagian ini sebagai definisi permulaan.
Dua algoritma

Susun atur jadual atribut css yang ditakrifkan pada elemen akan menentukan algoritma yang digunakan dalam pengiraan reka letak jadual. Ia mempunyai dua nilai, auto dan tetap. Dalam keadaan biasa, nilai lalai auto digunakan.

Perbezaan antara kedua-dua algoritma ini ialah sama ada reka letak lebar jadual berkaitan dengan kandungan data dalam jadual. Artikel ini akan membincangkan prinsip pengiraan susun atur jadual dalam dua nilai ini.
Susun atur jadual automatik-auto

Ciri reka letak jadual automatik ialah reka letak lebar jadual berkaitan dengan semua kandungan data dalam jadual Ia perlu mendapatkan semua kandungan jadual untuk menentukan reka letak lebar akhir, dan kemudian memaparkannya bersama-sama.

Dari sudut pandangan ini, perkara utama ialah "berkaitan dengan kandungan". Apakah yang berlaku jika jadual mentakrifkan lebar tetap (500px di sini), tetapi semua sel tidak mempunyai lebar yang ditentukan (hanya lebar yang ditentukan CSS dibincangkan)? Mari lihat hasilnya:
2015728174002286.jpg (538×116)

Dalam jadual di atas, bahagian kosong ditulis dengan ruang. Selepas perbandingan, perkara berikut boleh didapati:

Lajur 2 dan lajur 3 mempunyai lebar yang sama.
Nisbah antara lebar lajur pertama dan lebar mana-mana lajur berikutnya nampaknya ialah 2:1.
Termasuk jidar dan pelapik, jumlah lebar semua lajur adalah sama dengan lebar yang ditakrifkan oleh jadual.

Setiap sel tidak mempunyai lebar yang ditentukan, jadi reka letak lebar ditentukan sepenuhnya oleh data kandungan tertentu (maklumat teks). Bagaimana untuk menerangkan keputusan sedemikian? Mula-mula anda boleh membuat spekulasi secara intuitif tentang logik ini:

Langkah 1, pilih yang mempunyai kandungan teks yang paling banyak (difahamkan sebagai lebar terluas teks tanpa pembalut baris) daripada setiap lajur sebagai "wakil".
Langkah 2, bandingkan lebar "wakil" setiap lajur, dan kemudian tetapkan mereka jumlah lebar jadual, termasuk jidar dan pelapik, mengikut hubungan berkadar lebarnya.

Merujuk kepada logik di atas, mari kita semak jadual sebelumnya. Perhatikan bahawa sebelum ini dikatakan bahawa nisbah lebar "nampaknya" adalah 2:1 Mungkinkah ini? Mari kita lihat versi tanpa padding:
2015728174128545.jpg (558×87)

Gunakan alat penyahpepijatan bahagian hadapan untuk melihat dengan lebih dekat pada lebar sel di atas Anda akan mendapati bahawa jadual ini berbeza daripada sebelumnya dan nisbahnya sangat hampir dengan 2:1 (ya, titik kecil ini. adalah kerana sempadan, tetapi tidak ada Sempadan tidak dapat membezakan lajur).

Dapat dilihat bahawa apabila menganalisis hubungan nisbah lebar, lebar kandungan, padding, dan sempadan akan diambil kira. Ini juga menunjukkan bahawa ia bukan ukuran bilangan aksara, tetapi ukuran lebar yang boleh diduduki oleh aksara tanpa pemisah baris (2:1 di sini berasal daripada fakta bahawa aksara Cina mempunyai lebar yang sama). Sememangnya, menggunakan padding hanyalah untuk membuat meja yang lebih cantik :).

Apa yang berlaku apabila terdapat definisi lebar? Berikut ialah jadual dengan takrifan lebar untuk sesetengah sel:
2015728174212099.jpg (553×142)

Kod html yang sepadan ialah:

Kod XML/HTMLSalin kandungan ke papan keratan
  1. <meja kelas="meja_pameran" >  
  2.     <tr>  
  3.         <th>一二<><🎜 🎜>ke>  
  4.         
  5. <ke gaya="lebar: 200px;"> th>  
  6.         
  7. <th> <🎜 ke>       
  8. tr>       
  9. <tr>           
  10. <td gaya="lebar: 5px;"> td>           
  11. <td>td>           
  12. <td> <🎜 td>       
  13. tr>       <
  14. tr>           <
  15. td> <🎜 td>           <
  16. td gaya="lebar: 70px;"> td>           <
  17. td>一二三四< >td>       
  18. tr
  19. >  
  20. jadual
  21. >  

    Perkara berikut boleh didapati dalam jadual di atas:

    Lebar sebenar sel dengan lebar 5px ialah 13px, iaitu tepat lebar satu aksara Cina Sel dengan aksara Cina dalam lajur yang sama menyusun teks dalam bentuk lebar sel minimum (jadi,. garisan diubah).
    Sel yang lebarnya ditetapkan kepada 200px mempunyai lebar sebenar 200px, walaupun terdapat takrifan lebar 70px dalam lajur yang sama.
    Lajur ketiga, yang tidak mempunyai definisi lebar yang tepat, akhirnya mendapat keseluruhan baki lebar jadual selepas memperuntukkan lajur 1 dan 2.

    Inferensnya ialah apabila terdapat lajur dengan takrifan lebar dan lajur tanpa takrifan lebar:

    Jika lebar sel yang ditentukan adalah kurang daripada lebar susunan minimum kandungannya (bertentangan dengan susunan bukan balutan, lebar yang diperlukan oleh sel apabila seberapa banyak baris yang mungkin disusun dalam sel), maka lajur di mana sel berada, Kandungan akan dibentangkan dalam susunan terkecil yang mungkin.
    Jika lebar kandungan sel dalam lajur yang sama (tanpa pembalut baris, perkataan ini bermaksud ini kemudian) adalah lebih kecil daripada takrifan lebar terbesar dalam lajur, maka lebar sebenar lajur adalah sama dengan takrifan lebar.
    Untuk lajur tanpa takrifan lebar, jadual akan memperuntukkan lebar kepada lajur dengan takrifan lebar dahulu, dan kemudian memberikannya kepada lajur tersebut (sekali lagi, nisbah antara lajur bergantung pada lebar kandungan).

    Lajur hadapan tanpa definisi lebar boleh dianggap sebagai kes 1. Sesetengah lajur di sini mempunyai takrif lebar, dan ada yang tidak, yang boleh dianggap sebagai kes 2. Berikut ialah kes 3, iaitu, apabila semua lajur mempunyai takrifan lebar:
    2015728174233994.jpg (549×98)

    Kod html yang sepadan:

    Kod XML/HTMLSalin kandungan ke papan keratan
    1. <meja kelas="meja_pameran meja_pameran"<_tiada_padding >>  
    2.     <tr>  
    3.         <ke gaya="lebar: 50px;"> th>  
    4.         <ke gaya="lebar: 50px;"> th>  
    5.         <ke gaya="lebar: 100px;"> th>  
    6.     tr>  
    7.     <tr>  
    8.         <td> <🎜 td>  
    9.         
    10. <td> <🎜 td>           
    11. <td> <🎜 td>       
    12. tr>       <
    13. tr>           <
    14. td> <🎜 td>           <
    15. td> <🎜 td>           <
    16. td
    17. > <🎜 td>       tr
    18. >   jadual
    19. >  

      Dalam jadual di atas, pelapik dialih keluar, jadi nilai boleh ditakrifkan dengan jelas mengikut lebar dan nisbah lebar ketiga-tiga lajur ini ialah 2:1:1. Terdapat satu lagi syarat di sini, iaitu, lebar kandungan dalam sel tidak melebihi nilai definisi lebar. Selepas ujian, IE7 dan ke bawah berkelakuan berbeza daripada pelayar lain apabila kandungan melebihi nilai definisi lebar.

      Daripada contoh jadual ini, kita boleh tahu bahawa jika semua lajur mempunyai takrifan lebar dan jumlah nilai takrifan lebar ini adalah kurang daripada lebar jadual, jadual akan terus memperuntukkan lebar yang sepadan dengan lebarnya. nilai definisi lebar Baki lebar, mengikut kadar lebarnya, juga diperuntukkan kepada mereka.

      Di atas ialah analisis tiga situasi apabila susun atur jadual automatik ditakrifkan dan jadual itu sendiri mempunyai lebar tetap. Jika jadual itu sendiri tidak mentakrifkan lebar, akan ada lebih banyak situasi, dan ia akan berkaitan dengan blok yang mengandungi (butiran) jadual Jika ada peluang yang sesuai pada masa hadapan, kita akan membincangkannya (sehingga-. dipanggil ruang artikel adalah terhad...).
      Susun atur meja tetap-tetap

      Ciri susun atur jadual tetap ialah susun atur lebar jadual tidak ada kaitan dengan kandungan data dalam jadual Ia hanya perlu menerima maklumat baris pertama jadual untuk menentukan susun atur lebar akhir dan mula memaparkan.

      Reka letak jadual tetap adalah "bebas kandungan" dan ia menekankan "baris pertama". Sila lihat contoh jadual berikut:
      2015728174250768.jpg (551×165)

      Kod html yang sepadan:

      Kod XML/HTMLSalin kandungan ke papan keratan
      1. <meja kelas="meja_pameran meja_pameran_ditetapkan">  
      2.     <tr>  
      3.         <ke gaya="lebar: 50px;">ke>  
      4.         <th>一二<><🎜 🎜>ke>  
      5.         
      6. <th>一二三四< >ke>       
      7. tr>       
      8. <tr>           
      9. <td>艾丝蒂尔·布莱>特;> /td>           
      10. <
      11. td lebar=;"10 "> td>           <
      12. td> <🎜 td>       
      13. tr>       <
      14. tr>           <
      15. td gaya="lebar: 5px;"> td>           <
      16. td> <🎜 td>           <
      17. td
      18. > <🎜 td>       tr
      19. >   jadual
      20. >  

        Logik susun atur jadual tetap adalah lebih mudah dan dinyatakan seperti berikut:

        Hanya ambil maklumat baris pertama, abaikan kandungan semua sel selepas baris pertama dan definisi lebar
        Dalam baris pertama, jika sel mempunyai definisi lebar, peruntukkan lebar yang diperlukan dahulu, dan kemudian baki lebar diagihkan sama rata kepada sel tanpa definisi lebar
        Taburan lebar sel dalam baris pertama akan menentukan reka letak lebar jadual dan kandungan selepas baris pertama tidak akan mengubah reka letak.

        Perlu juga diambil perhatian bahawa apabila menggunakan reka letak jadual tetap, anda mesti menentukan lebar elemen jadual Jika lebarnya tidak ditentukan (iaitu, nilai lalai automatik), penyemak imbas akan menggunakan reka letak jadual automatik .
        Kenyataan Penamat

        Berkaitan dengan jadual, sebenarnya terdapat elemen seperti , , , , tetapi dalam penggunaan yang paling biasa, ia tidak diperlukan. Malah, ia juga diambil kira dalam pengiraan susun atur jadual. Ditambah dengan situasi penggabungan sel, anda mungkin boleh bayangkan betapa rumitnya pengiraan susun atur jadual.

        Dokumen W3C menyebut bahawa pengiraan susun atur jadual (susun atur jadual automatik) belum lagi menjadi spesifikasi. Untuk penerangan W3C tentang pengiraan susun atur jadual, sila rujuk kepada algoritma lebar Jadual.
        Kesimpulan

        Malah, setakat prinsip pengiraan susun atur jadual, membuat inferens terperinci sedemikian tidak begitu praktikal. Saya hanya mengatakan bahawa maklumat ini boleh digunakan sebagai rujukan apabila anda perlu menyelesaikan butirannya, walaupun tidak banyak peluang seperti ini.

        Walau bagaimanapun, kami boleh membuat kesimpulan yang lebih bermakna berdasarkan kandungan artikel ini: jadual mentakrifkan lebar, dan semua sel tidak menentukan lebar, maka jadual susun atur automatik akan cuba sedaya upaya untuk menghalang semua data anda daripada membalut, dan Jika anda menghadapi situasi di mana pemisah baris menjejaskan penampilan, ini bermakna anda mesti menyelaraskan data atau mengurangkan jidar dan bukannya cuba membuat semula peruntukan lebar sendiri.

        Kali ini saya melakukan pengukuran dan inferens sebenar seperti ini, saya rasa lebih mudah untuk difahami selepas memecahkan situasi tertentu dan kemudian menerangkannya daripada memberikan kenyataan yang sistematik dan lengkap sekaligus berlatih?

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan