ወደ ዋናው ይዘት ዝለል ወደ ሰነዶች ዳሰሳ ዝለል

በBootstrap ውስጥ ለቀኝ-ወደ-ግራ ጽሑፍ ድጋፍን እንዴት ማንቃት እንደሚቻል በአቀማመጥ፣ ክፍሎች እና መገልገያዎች ላይ ይማሩ።

ይተዋወቁ

በመጀመሪያ የመግቢያ ገጻችንን በማንበብ ከ Bootstrap ጋር ለመተዋወቅ እንመክራለን ። አንዴ ካለፉ በኋላ፣ RTLን እንዴት ማንቃት እንደሚቻል እዚህ ማንበብ ይቀጥሉ።

የ RTL አቀራረባችንን ስለሚያበረታታ ስለ RTLCSS ፕሮጀክት ማንበብ ሊፈልጉ ይችላሉ ።

የሙከራ ባህሪ

የRTL ባህሪው አሁንም የሙከራ ነው እና በተጠቃሚ ግብረመልስ መሰረት ሊዳብር ይችላል። የሆነ ነገር ተመልክተዋል ወይም ለመጠቆም ማሻሻያ አለዎት? ችግር ይክፈቱ ፣ ግንዛቤዎችዎን ቢያገኝልን ደስ ይለናል።

አስፈላጊ HTML

RTL በBootstrap-powered pages ውስጥ ለማንቃት ሁለት ጥብቅ መስፈርቶች አሉ።

  1. ኤለመንት dir="rtl"ላይ አዘጋጅ .<html>
  2. በንጥሉ ላይ ተገቢውን langባህሪ፣ እንደ lang="ar"፣ ያክሉ <html>

ከዚያ ሆነው የእኛን CSS የ RTL ስሪት ማካተት ያስፈልግዎታል። ለምሳሌ፣ RTL ከነቃው ጋር ለተቀናበረ እና ለተቀነሰው CSS የቅጥ ሉህ ይኸውና፡

<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.rtl.min.css" integrity="sha384-+qdLaIRZfNu4cVPK/PxJJEy0B0f3Ugv8i482AKY7gwXwhaCroABd086ybrVKTa0q" crossorigin="anonymous">

የጀማሪ አብነት

በዚህ የተሻሻለው የ RTL ማስጀመሪያ አብነት ውስጥ ከላይ የተጠቀሱትን መስፈርቶች ተንጸባርቀዋል።

<!doctype html>
<html lang="ar" dir="rtl">
  <head>
    <!-- Required meta tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">

    <!-- Bootstrap CSS -->
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.rtl.min.css" integrity="sha384-+qdLaIRZfNu4cVPK/PxJJEy0B0f3Ugv8i482AKY7gwXwhaCroABd086ybrVKTa0q" crossorigin="anonymous">

    <title>مرحبا بالعالم!</title>
  </head>
  <body>
    <h1>مرحبا بالعالم!</h1>

    <!-- Optional JavaScript; choose one of the two! -->

    <!-- Option 1: Bootstrap Bundle with Popper -->
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.bundle.min.js" integrity="sha384-ka7Sk0Gln4gmtz2MlQnikT1wXgYsOg+OMhuP+IlRH9sENBO0LRn5q+8nbTov4+1p" crossorigin="anonymous"></script>

    <!-- Option 2: Separate Popper and Bootstrap JS -->
    <!--
    <script src="https://cdn.jsdelivr.net/npm/@popperjs/[email protected]/dist/umd/popper.min.js" integrity="sha384-7+zCNj/IqJ95wo16oMtfsKbZ9ccEh31eOz1HGyDuCQ6wgnyJNSYdrPa03rtR1zdB" crossorigin="anonymous"></script>
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.min.js" integrity="sha384-QJHtvGhmr9XOIpI6YVutG+2QOK9T+ZnN4kzFN1RtK3zEFEIsxhlmWl5/YESvpZ13" crossorigin="anonymous"></script>
    -->
  </body>
</html>

የ RTL ምሳሌዎች

ከብዙ የ RTL ምሳሌዎች ውስጥ በአንዱ ይጀምሩ ።

አቀራረብ

የ RTL ድጋፍን ወደ Bootstrap የመገንባት አካሄዳችን የእኛን CSS እንዴት እንደምንጽፍ እና እንደምንጠቀምበት ከሚወስኑ ሁለት አስፈላጊ ውሳኔዎች ጋር አብሮ ይመጣል።

  1. በመጀመሪያ, በ RTLCSS ፕሮጀክት ለመገንባት ወሰንን. ይህ ከLTR ወደ RTL ስንንቀሳቀስ ለውጦችን ለመቆጣጠር እና ለመሻር አንዳንድ ኃይለኛ ባህሪያትን ይሰጠናል። እንዲሁም ከአንድ ኮድ ቤዝ ሁለት የBootstrap ስሪቶችን እንድንገነባ ያስችለናል።

  2. ሁለተኛ፣ አመክንዮአዊ ባህሪያት አቀራረብን ለመቀበል ጥቂት የአቅጣጫ ክፍሎችን ሰይመናል። አብዛኞቻችሁ ቀደም ሲል ከሎጂካዊ ንብረቶች ጋር መስተጋብር ፈጥረዋል ለተለዋዋጭ መገልገያዎቻችን - እነሱ የአቅጣጫ ባህሪያትን እንደ leftእና rightሞገስ ይተካሉ startእና end. ያ የክፍል ስሞችን እና እሴቶችን ያለምንም ክፍያ ለ LTR እና RTL ተገቢ ያደርገዋል።

ለምሳሌ፣ .ml-3ለ ሳይሆን margin-leftተጠቀም .ms-3

ከRTL ጋር መስራት በምንጫችን Sass ወይም በተጠናቀረ CSS በኩል ከነባሪው LTR ብዙም የተለየ መሆን የለበትም።

ከምንጩ ያብጁ

ወደ ማበጀት ሲመጣ የሚመረጠው መንገድ ተለዋዋጮችን፣ ካርታዎችን እና ድብልቅ ነገሮችን መጠቀም ነው። ይህ አካሄድ ለ RTL ተመሳሳይ ነው የሚሰራው፣ ምንም እንኳን ከተቀናጁ ፋይሎች ድህረ-ተሰራ ቢሆንም፣ RTLCSS እንዴት እንደሚሰራ እናመሰግናለን

ብጁ RTL እሴቶች

RTLCSS እሴት መመሪያዎችን በመጠቀም ፣ ተለዋዋጭ ውፅዓት ለ RTL የተለየ እሴት ማድረግ ይችላሉ። ለምሳሌ፣ በመላው የኮድ ቤዝ ክብደት ለመቀነስ ፣ አገባብ $font-weight-boldመጠቀም ትችላለህ ፡-/*rtl: {value}*/

$font-weight-bold: 700 #{/* rtl:600 */} !default;

ለነባሪያችን CSS እና RTL CSS የትኛው ወደሚከተለው ይወጣል፡

/* bootstrap.css */
dt {
  font-weight: 700 /* rtl:600 */;
}

/* bootstrap.rtl.css */
dt {
  font-weight: 600;
}

ተለዋጭ የቅርጸ-ቁምፊ ቁልል

ብጁ ቅርጸ-ቁምፊን እየተጠቀሙ ከሆነ፣ ሁሉም ቅርጸ-ቁምፊዎች የላቲን ያልሆኑትን ፊደላት እንደማይደግፉ ይወቁ። /*rtl:insert: {value}*/ከፓን-አውሮፓውያን ወደ አረብኛ ቤተሰብ ለመቀየር፣ የቅርጸ-ቁምፊ ቤተሰቦችን ስም ለመቀየር በፎንት ቁልልዎ ውስጥ መጠቀም ሊኖርብዎ ይችላል ።

ለምሳሌ፣ ከ Helvetica Neue WebfontLTR ወደ Helvetica Neue ArabicRTL ለመቀየር፣ የእርስዎ Sass ኮድ ይህን ይመስላል።

$font-family-sans-serif:
  Helvetica Neue #{"/* rtl:insert:Arabic */"},
  // Cross-platform generic font family (default user interface font)
  system-ui,
  // Safari for macOS and iOS (San Francisco)
  -apple-system,
  // Chrome < 56 for macOS (San Francisco)
  BlinkMacSystemFont,
  // Windows
  "Segoe UI",
  // Android
  Roboto,
  // Basic web fallback
  Arial,
  // Linux
  "Noto Sans",
  // Sans serif fallback
  sans-serif,
  // Emoji fonts
  "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !default;

LTR እና RTL በተመሳሳይ ጊዜ

ሁለቱም LTR እና RTL በተመሳሳይ ገጽ ይፈልጋሉ? ለ RTLCSS ሕብረቁምፊ ካርታዎች ምስጋና ይግባውና ይህ በጣም ቀጥተኛ ነው። የእርስዎን @imports በክፍል ይሸፍኑ እና ለ RTLCSS ብጁ ዳግም መሰየምን ያቀናብሩ

/* rtl:begin:options: {
  "autoRename": true,
  "stringMap":[ {
    "name": "ltr-rtl",
    "priority": 100,
    "search": ["ltr"],
    "replace": ["rtl"],
    "options": {
      "scope": "*",
      "ignoreCase": false
    }
  } ]
} */
.ltr {
  @import "../node_modules/bootstrap/scss/bootstrap";
}
/*rtl:end:options*/

Sass ን ከዚያ RTLCSS ን ካሄዱ በኋላ በ CSS ፋይሎችዎ ውስጥ ያለው እያንዳንዱ መራጭ በ .ltrእና .rtlለ RTL ፋይሎች ይዘጋጃል። አሁን ሁለቱንም ፋይሎች በአንድ ገጽ ላይ መጠቀም ይችላሉ፣ እና አንዱን ወይም ሌላ አቅጣጫ ለመጠቀም በቀላሉ ይጠቀሙ .ltrወይም .rtlበመሳሪያዎችዎ መጠቅለያዎች ላይ።

የጠርዝ ጉዳዮች እና የታወቁ ገደቦች

ይህ አካሄድ ለመረዳት የሚቻል ቢሆንም፣ እባክዎን ለሚከተሉት ትኩረት ይስጡ።

  1. በሚቀይሩበት ጊዜ እና በዛው መሰረት ማከልዎን እና .ltrባህሪዎን .rtlያረጋግጡ ።dirlang
  2. ሁለቱንም ፋይሎች መጫን እውነተኛ የአፈጻጸም ማነቆ ሊሆን ይችላል፡ አንዳንድ ማመቻቸትን አስቡበት እና ምናልባት ከነዚህ ፋይሎች ውስጥ አንዱን በተመሳሰል መልኩ ለመጫን ይሞክሩ ።
  3. በዚህ መንገድ መክተቻ ቅጦች የእኛ form-validation-state()ድብልቅ እንደታሰበው እንዳይሰራ ይከለክላል፣ ስለዚህ በእራስዎ ትንሽ እንዲያስተካክሉት ይፈልጋሉ። #31223 ይመልከቱ

የዳቦ ፍርፋሪ መያዣ

የዳቦ ፍርፋሪ መለያ የራሱ የሆነ አዲስ ተለዋዋጭ - ማለትም - $breadcrumb-divider-flippedነባሪ የሚያስፈልገው ብቸኛው ጉዳይ $breadcrumb-dividerነው ።

ተጨማሪ መገልገያዎች