การใช้งาน tabs ใน ionicframework ตอนที่ 13

เขียนเมื่อ 9 ปีก่อน โดย Ninenik Narkdee
ionicframework

คำสั่ง การ กำหนด รูปแบบ ตัวอย่าง เทคนิค ลูกเล่น การประยุกต์ การใช้งาน เกี่ยวกับ ionicframework

ดูแล้ว 9,330 ครั้ง


tabs ใน ionicframework เราสามารถเลือกใช้งานได้จาก 2 วิธีคือ 
การใช้ ion-tabs และ การใช้ css class
 
โดยเนื้อหาที่อธิบายจากอ้างอิงจากสองลิ้งค์นี้
 
โค้ดตัวอย่างและไฟล์ที่เกี่ยวข้อง จะขอใช้งานจากบทความก่อนหน้า ดูได้ที่
 
การใช้งาน ionicmodal ใน ionicframework ตอนที่ 10 
 
 
 
 การใช้งาน tabs แบบที่ 1 ด้วย ion-tabs 
 
iontabs นั้นเราจะใช้งาน โดยแบ่งหน้าที่จะแสดงออกเป็นแท็บเมนู เช่น เรามีไฟล์
welcome.html 1 ไฟล์ ต้องการแสดงแบบมีแท็บเมนู และเนื้อหาในไฟล์ welcome.html
 
เราจะใช้โค้ดเบื้องต้น ของ ion-tabs ดังนี้
 
ไฟล์ welcome.html วาโครงสำหรับใช้ tabs
 
<ion-tabs class="tabs-assertive tabs-icon-only">

  <ion-tab title="Home" icon-on="ion-ios7-filing" icon-off="ion-ios7-filing-outline">
    <!-- Tab 1 content -->
  </ion-tab>

  <ion-tab title="About" icon-on="ion-ios7-clock" icon-off="ion-ios7-clock-outline">
    <!-- Tab 2 content -->
  </ion-tab>

  <ion-tab title="Settings" icon-on="ion-ios7-gear" icon-off="ion-ios7-gear-outline">
    <!-- Tab 3 content -->
  </ion-tab>

</ion-tabs>
 
จากนั้น ในส่วจของ tab 1 content หรือเนื้อหาของแท็บ เราก็ใส่โค้ดหน้า
app ปกติที่เราใช้งานลงไปซึ่งประกอบไปด้วย header และ content ก็จะได้
 
หมายเหตุ: ห้ามนำ ion-tabs ไปวางไว้ด้านในของ ion-content เพราะจะทำ
ให้การแสดงผลผิดพลาดได้
 
โค้ดไฟล์ welcome.html เบื้องต้นดังนี้
 
<ion-tabs class="tabs-assertive tabs-icon-only">

  <ion-tab title="Home" icon-on="ion-ios7-filing" icon-off="ion-ios7-filing-outline">
    <!-- Tab 1 content -->
    
<ion-header-bar class="bar bar-header bar-assertive">  
<button menu-toggle="left" class="button button-icon icon ion-navicon"></button>  
<h1 class="title">My Ionic</h1>  
</ion-header-bar>  
<!--            กำหนด class ให้กับ ion-content กรณี มี header-->  
<ion-content  class="scroll-content ionic-scroll  has-header">  

  
<div class="list card">

  <div class="item item-body">
   <h2>Welcome</h2>
    <p>
    This is welcome.html template
      <br>
      <br>
      <br>

    </p>
  </div>

</div>            
    
</ion-content>       
    
  </ion-tab>

  <ion-tab title="About"  icon-on="ion-ios7-clock" icon-off="ion-ios7-clock-outline">
    <!-- Tab 2 content -->
    content tab 2
  </ion-tab>

  <ion-tab title="Settings" icon-on="ion-ios7-gear" icon-off="ion-ios7-gear-outline">
    <!-- Tab 3 content -->
  content tab 3
  </ion-tab>

</ion-tabs>
 
ดูตัวอย่าง
 
 
จะสังเกตเห็นว่า การใช้แท็บเมนูลักษณะนี้ จะเป็นการโหลดข้อมูลเข้ามาครั้งแรกพร้อมกัน และ
ข้อมูลในแต่ละแท็บเมนู จะใช้ $scope เดียวกัน 
ข้อจำกัดคือเวลาใช้งาน จะต้องไปกำหนดทุกครั้งที่ต้องการใช้ หาก app ของเราต้อง
การให้มีแท็บเมนูทุกหน้า รวมทั้งมีความยืดหยุ่นน้อยกว่าการใช้งานในรูปแบบ css
 
การปรับแต่งการใช้าน ion-tabs สามารถทำได้โดยการใช้ css class ดังนี้
 
กำหนดสี 
tabs-{ชื่อสีของ ionic} เช่น tabs-positive 
 
ให้แสดงเฉพาะ icon ไม่แสดงข้อควม 
tabs-icon-only
 
ให้แสดง icon และข้อความ โดยให้ icon อยู่ด้านบนของข้อความ
tabs-icon-top
 
ให้แสดง icon และข้อความ โดยให้ icon อยู่ด้านซ้ายของข้อความ
tabs-icon-left
 
การกำหนดให้มีแถบคาดแท็บเมนู ที่กำลังใช้งานอยู่ หรือ active อยู่
tabs-striped
 
กำหนดสีพื้นหลังให้กับแท็บเมนู จะใช้คู่กับ tabs-striped
tabs-background-{ชื่อสีของ ionic}  เช่น tabs-background-assertive 
 
กำหนดสี จะใช้คู่กับ tabs-striped 
tabs-color-{ชื่อสีของ ionic} เช่น tabs-color-balanced
 
ตัวอย่างการกำหนดและรูปประกอบ
 
<ion-tabs class="tabs-assertive ">  
 
ionic13-1
 
 
<ion-tabs class="tabs-assertive tabs-icon-left">  
 
ionic13-2
 
<ion-tabs class="tabs-assertive tabs-icon-top">  
 
ionic13-3
 
<ion-tabs class="tabs-striped tabs-top tabs-icon-top tabs-background-assertive tabs-stable"> 
 
ionic13-4
 
<ion-tabs class="tabs-striped tabs-icon-only tabs-background-assertive tabs-color-dark">
 
ionic13-5
 
 
 
 
การใช้งาน tabs แบบที่ 2 ด้วย css class
 
การใช้งาน และการกำหนด tabs แบบ css class ก็จะใช้รูปแบบตามที่อธิบายด้านบน
แต่จะไม่ได้มีการเรียกใช้งาน ion-tabs จะใช้แท็ก html ปกติเช่น div กำหนดราย
ละเอียดต่างของ tabs และจัดรูปแบบด้วย css class  การแสดงข้อมูลจะใช้เป็นแบบ
ลิ้งค์ไปที่ไฟล์ หรือเรียกใช้ฟังก์ชั่น ng-click เพื่อทำงาน ต่างจาก ion-tabs ที่จะใช้
วิธีแสดงเนื้อหาแท็บเมนู ที่ถูกซ่อนไว้
 
รูปแบบแท็บเมนู ที่กำหนด้วย css class อย่างง่าย
 
   <div class="tabs">
    <a href="#/" class="tab-item">
        <i class="icon ion-home"></i>
        Home
    </a>
    <a href="#/aboutus" class="tab-item">
        <i class="icon ion-ios7-clock"></i>
        About us
    </a>
    <a href="#/contactus" class="tab-item" >
        <i class="icon ion-star"></i>
        Contact us
    </a>
    </div>
 
กรณีที่ต้องการใช้งาน  tabs-striped เราจะต้องเพิ่ม div เข้าไปอีกขึ้นจะได้เป็น
 
 <div class="tabs-striped tabs-background-dark tabs-color-assertive">
    <div class="tabs">
        <a class="tab-item active" href="#/">
            <i class="icon ion-home"></i>
            Home
        </a>
        <a class="tab-item" href="#/aboutus">
            <i class="icon ion-ios7-clock"></i>
            About us
        </a>
        <a class="tab-item" href="#/contactus">
            <i class="icon ion-star"></i>
            Contact us
        </a>   
    </div>
</div>
 
 
ตัวอย่างโค้ดการใช้งานในหน้า aboutus.html
 
<ion-header-bar class="bar bar-header bar-assertive">  
<button menu-toggle="left" class="button button-icon icon ion-navicon"></button>  
<h1 class="title">About Us</h1>  
<a nav-clear href="#/" class="button button-icon icon ion-home"></a>
</ion-header-bar>  
<!--            กำหนด class ให้กับ ion-content กรณี มี header-->  
<ion-content  class="scroll-content ionic-scroll  has-header">  

<div class="list card">

  <div class="item item-body">
   <h2>About Us</h2>
    <p>
      This is aboutus.html template
    </p>
  </div>

</div>   
    
</ion-content>   
<div class="tabs tabs-assertive ">
<a href="#/" class="tab-item">
    <i class="icon ion-home"></i>
    Home
</a>
<a href="#/aboutus" class="tab-item">
    <i class="icon ion-ios7-clock"></i>
    About us
</a>
<a href="#/contactus" class="tab-item" >
    <i class="icon ion-star"></i>
    Contact us
</a>
</div>
 
การจัดวาง จะต่างจากการใช้งาน ion-tabs โดยจะวางไว้ด้านนอกของ 
ion-content
การใช้งาน แบบ css class เราจำเป็นต้องกำหนดค่าต่างๆ เองเช่น
กำหนดลักษณะของแท็บเมนูที่ active กรณีใช้งานใน ion-view
 
ตัวอย่าง
 
 
 
มาดูรูปแบบการใช้งาน tabs แบบ css class แบบกำหนดให้ใช้กับทุกๆหน้า 
 
 
โค้ดการจัดวางคู่กับการใช้งาน side menu และ ion-view ไฟล์ index.html
 
<!DOCTYPE html>
<html ng-app="myIonicApp"> 
    <head>
        <meta charset="utf-8" />
        <meta name="format-detection" content="telephone=no" />
        <meta name="msapplication-tap-highlight" content="no" />
        <meta name="viewport" content="initial-scale=1, maximum-scale=1, user-scalable=no, width=device-width">
        <link href="css/ionic.css" rel="stylesheet">
        <script type="text/javascript" src="js/ionic.bundle.js"></script>  
        <script type="text/javascript" src="app.js"></script>
        <title>My Ionic 3</title>
    </head>
    <body ng-controller="myIonicHome">
  
 
      <ion-side-menus>  
        <!-- Center content -->  
        <ion-side-menu-content>  
               
            <ion-nav-bar class="bar bar-header bar-assertive">
              <ion-nav-back-button class="button-clear">
                <i class="ion-arrow-left-c"></i> Back
              </ion-nav-back-button>                     
            </ion-nav-bar>             
            <ion-nav-view animation="slide-left-right">

            </ion-nav-view>
            
         <div class="tabs tabs-energized tabs-icon-top">
        <a nav-clear href="#/" class="tab-item">
            <i class="icon ion-home"></i>
            Home
        </a>
        <a nav-clear href="#/aboutus" class="tab-item">
            <i class="icon ion-ios7-clock"></i>
            About us
        </a>
        <a nav-clear href="#/contactus" class="tab-item" >
            <i class="icon ion-star"></i>
            Contact us
        </a>
        </div>     
               
        </ion-side-menu-content>  
  
        <!-- Left menu -->  
        <ion-side-menu side="left">  
            <ion-header-bar class="bar bar-header bar-assertive">  
                <h1 class="title">Menu</h1>  
            </ion-header-bar>  
            <ion-content>  

            <div class="list">
                <a nav-clear nav-clear menu-close class="item item-icon-left" href="#/">
                    <i class="icon ion-home"></i>
                    Home
                </a>
                <a nav-clear menu-close class="item item-icon-left" href="#/aboutus">
                    <i class="icon ion-at"></i>
                    About Us
                </a>
                <a nav-clear menu-close class="item item-icon-left item-icon-right" href="#/contactus">
                    <i class="icon ion-email"></i>
                    Contact Us
                    <i class="icon ion-ios7-telephone-outline"></i>
                </a>
            </div>              
                                                      
            </ion-content>  
        </ion-side-menu>  
  
    </ion-side-menus>  
   
    </body>
</html>
 
 
 
เนื้อหาเกี่ยวกับการใช้งาน tabs จะมีเพิ่มเติมในบทความต่อไป


กด Like หรือ Share เป็นกำลังใจ ให้มีบทความใหม่ๆ เรื่อยๆ น่ะครับ







เนื้อหาที่เกี่ยวข้อง









URL สำหรับอ้างอิง





คำแนะนำ และการใช้งาน

สมาชิก กรุณา ล็อกอินเข้าระบบ เพื่อตั้งคำถามใหม่ หรือ ตอบคำถาม สมาชิกใหม่ สมัครสมาชิกได้ที่ สมัครสมาชิก


  • ถาม-ตอบ กรุณา ล็อกอินเข้าระบบ
  • เปลี่ยน


    ( หรือ เข้าใช้งานผ่าน Social Login )







เว็บไซต์ของเราให้บริการเนื้อหาบทความสำหรับนักพัฒนา โดยพึ่งพารายได้เล็กน้อยจากการแสดงโฆษณา โปรดสนับสนุนเว็บไซต์ของเราด้วยการปิดการใช้งานตัวปิดกั้นโฆษณา (Disable Ads Blocker) ขอบคุณครับ