整合營銷服務(wù)商

          電腦端+手機(jī)端+微信端=數(shù)據(jù)同步管理

          免費(fèi)咨詢熱線:

          nginx的SCRIPT_NAME, PATH_INFO多了index.php問題

          使用nginx進(jìn)行 反向代理配置時(shí)通過正則表達(dá)式配置location后發(fā)現(xiàn)

          通過$_SERVER['SCRIPT_NAME']; 與$_SERVER['PATH_INFO'] 發(fā)現(xiàn)直接獲取了整個(gè)uri地址

          訪問uri: 127.0.0.1/index.php/site/login

          正常情況應(yīng)該為index.php

          先獲取為index.php/site/login

          以下是解決方法

          server { 
          listen 80; 
          server_name test.com; 
           
          access_log /home/swin/oaih/dev/logs/access.log; 
          error_log /home/swin/oaih/dev/logs/error.log; 
           
          root /home/swin/oaih/dev/public; 
          index index.php index.html index.htm; 
           
          location / { 
          if (!-e $request_filename) { 
          rewrite ^/(.*)$ /index.php/$1 last; 
          } 
          } 
           
          location ~ .php$ { 
          fastcgi_pass 127.0.0.1:9000; 
          fastcgi_index index.php; 
          fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 
           
          include /etc/nginx/fastcgi_params; 
          } 
           
          location ~ .php($|/) { 
           
          set $script $uri; 
          set $path_info ""; 
           
          if ($uri ~ "^(.+.php)(/.+)") { 
          set $script $1; 
          set $path_info $2; 
          } 
           
          fastcgi_pass 127.0.0.1:9000; 
          fastcgi_index index.php; 
          fastcgi_param SCRIPT_FILENAME $document_root$script; 
          fastcgi_param SCRIPT_NAME $script; 
          fastcgi_param PATH_INFO $path_info; 
           
          fastcgi_param QUERY_STRING $query_string; 
          fastcgi_param REQUEST_METHOD $request_method; 
          fastcgi_param CONTENT_TYPE $content_type; 
          fastcgi_param CONTENT_LENGTH $content_length; 
           
          fastcgi_param REQUEST_URI $request_uri; 
          fastcgi_param DOCUMENT_URI $document_uri; 
          fastcgi_param DOCUMENT_ROOT $document_root; 
          fastcgi_param SERVER_PROTOCOL $server_protocol; 
           
          fastcgi_param GATEWAY_INTERFACE CGI/1.1; 
          fastcgi_param SERVER_SOFTWARE nginx; 
           
          fastcgi_param REMOTE_ADDR $remote_addr; 
          fastcgi_param REMOTE_PORT $remote_port; 
          fastcgi_param SERVER_ADDR $server_addr; 
          fastcgi_param SERVER_PORT $server_port; 
          fastcgi_param SERVER_NAME $server_name; 
          fastcgi_param REDIRECT_STATUS 200; 
           
          } 
           
          } 
          

          第一個(gè)位置指令設(shè)立的基本選項(xiàng),而第二個(gè)location指令匹配一個(gè)請求到自身的index.php,并把它傳遞到FastCGI來處理。下一次請求index.php是沒有進(jìn)行正確的配置。

          在處理我們的問題的整個(gè)配置文件的關(guān)鍵部分是這樣的:

          location ~ .php($|/) { 
           
          set $script $uri; 
          set $path_info ""; 
           
          if ($uri ~ "^(.+.php)(/.+)") { 
          set $script $1; 
          set $path_info $2; 
          } 
           
          fastcgi_pass 127.0.0.1:9000; 
          fastcgi_index index.php; 
          fastcgi_param SCRIPT_FILENAME $document_root$script; 
          fastcgi_param SCRIPT_NAME $script; 
          fastcgi_param PATH_INFO $path_info; 
          } 
          

          location指定匹配所有的php請求將不指定為先前的全部uri, 它還清空$path-info變量, if語句匹配任何類似下面的請求:http://mysite/index.php/foo和放入的index.php的$script變量和/ foo $path_info變量。

          $script and $path_info將被插入到服務(wù)器變量SCRIPT_NAME和PATH_INFO的fastcgi的參數(shù),并允許PHP妥善處理請求。

          ant3頁面中css變量的使用

          在使用 Vant3 開發(fā)單頁面應(yīng)用時(shí),如果需要修改 css 變量的值,可以通過 ConfigProvider 全局配置來實(shí)現(xiàn)。

          首先, 通過以下方式來全局注冊組件:

          import { createApp } from 'vue';
          import { ConfigProvider } from 'vant';
          
          const app = createApp();
          app.use(ConfigProvider);

          然后,通過 ConfigProvider 覆蓋 CSS 變量:

          ConfigProvider 組件提供了覆蓋 CSS 變量的能力,你需要在根節(jié)點(diǎn)包裹一個(gè) ConfigProvider 組件,并通過 theme-vars 屬性來配置一些主題變量。

          <van-config-provider :theme-vars="themeVars">
            <van-form>
              <van-field name="rate" label="評分">
                <template #input>
                  <van-rate v-model="rate" />
                </template>
              </van-field>
              <van-field name="slider" label="滑塊">
                <template #input>
                  <van-slider v-model="slider" />
                </template>
              </van-field>
              <div style="margin: 16px">
                <van-button round block type="primary" native-type="submit">
                  提交
                </van-button>
              </div>
            </van-form>
          </van-config-provider>
          import { ref } from 'vue';
          
          export default {
            setup() {
              const rate = ref(4);
              const slider = ref(50);
          
              // themeVars 內(nèi)的值會被轉(zhuǎn)換成對應(yīng) CSS 變量
              // 比如 sliderBarHeight 會轉(zhuǎn)換成 `--van-slider-bar-height`
              const themeVars = {
                rateIconFullColor: '#07c160',
                sliderBarHeight: '4px',
                sliderButtonWidth: '20px',
                sliderButtonHeight: '20px',
                sliderActiveBackgroundColor: '#07c160',
                buttonPrimaryBorderColor: '#07c160',
                buttonPrimaryBackgroundColor: '#07c160',
              };
          
              return {
                rate,
                slider,
                themeVars,
              };
            },
          };

          ConfigProvider 僅影響它的子組件的樣式,不影響全局 root 節(jié)點(diǎn)。

          實(shí)例:修改頂部導(dǎo)航欄的背景色

          代碼如下:

          文的目的主要是展示CSS變量是如何工作的。隨著Web應(yīng)用程序變得越來越大,CSS變得越來越大,越來越多,而且很多時(shí)候都很亂,在良好的上下文中使用CSS變量,為您提供重用和輕松更改重復(fù)出現(xiàn)的CSS屬性的機(jī)制。

          在“純粹的”CSS支持變量之前,我們有像LessSass這樣的預(yù)處理器。但是它們需要在使用前進(jìn)行編譯,因此(有時(shí))會增加額外的復(fù)雜性。

          如何定義和使用CSS變量

          從我們最熟悉的語言JavaScript開始:在JavaScript中定義變量使用vars。

          要聲明一個(gè)簡單的JavaScript var,如下內(nèi)容:

          var mainColor = 'red';

          要聲明一個(gè)CSS變量,您必須在該var的名稱前添加一個(gè)雙短劃線。例如:

          body{ --color:red; }

          現(xiàn)在,為了使用CSS變量的值,我們可以使用var(...)函數(shù)。如下:

          .demo{ background:var(--color); }

          管理CSS變量的最簡單方法是將它們聲明為:root偽類。鑒于CSS變量遵循規(guī)則,就像任何其他CSS定義一樣,將它們放在:root中將確保所有選擇器都可以訪問這些變量。

          :root{ --color:red; } 
          .demo{ background:var(--color); } 
          p{ color:var(--color); }

          瀏覽器支持CSS變量?

          瀏覽器對CSS變量的支持還算不錯(cuò)的。只是IE瀏覽器不支持。那么您將看到所有主流瀏覽器都支持開箱即用的CSS變量。無論是手機(jī)還是臺式機(jī)。

          CSS變量的實(shí)質(zhì)應(yīng)用

          示例1 - 管理顏色

          到目前為止,使用CSS變量的最佳候選者之一是管理網(wǎng)頁的顏色。我們可以將它們放在變量中,而不是一遍又一遍地復(fù)制和粘貼相同的顏色。如果有人要求我們更新特定的綠色陰影或使所有按鈕變?yōu)榧t色而不是藍(lán)色,那么只需更改該CSS變量的值,就是這樣。您不必搜索和替換該顏色的所有實(shí)例。

          CSS代碼

          /*css_vars.css*/
          :root {
            --primary-color: #ed6564;
            --accent-color: #388287;
          }
          html {
            background-color: var(--primary-color);
          }
          h3 {
            border-bottom: 2px solid var(--primary-color);
          }
          button {
            color: var(--accent-color);
            border: 1px solid var(--accent-color);
          }
          p {
            color: var(--accent-color);
          }
          
          /*base.css*/
          * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
          }
          html {
            padding: 30px;
            font: normal 13px/1.5 sans-serif;
            color: #546567;
            background-color: var(--primary-color);
          }
          .container {
            background: #fff;
            padding: 20px;
          }
          h3 {
            padding-bottom: 10px;
            margin-bottom: 15px;
          }
          p {
            background-color: #fff;
            margin: 15px 0;
          }
          button {
            margin:0 5px;
            font-size: 13px;
            padding: 8px 12px;
            background-color: #fff;
            border-radius: 3px;
            box-shadow: none;
            text-transform: uppercase;
            font-weight: bold;
            cursor: pointer;
            opacity: 0.8;
            outline: 0;
          }
          button:hover {
            opacity: 1;
          }
          .center {
            text-align: center;
          }

          HTML代碼

          <div class="container">
            <h3>就業(yè)協(xié)議書</h3>
            <p>就業(yè)協(xié)議書,全稱是《全國普通高等學(xué)校畢業(yè)生就業(yè)協(xié)議書》,是由教育部高校學(xué)生司統(tǒng)一制訂的。根據(jù)國家規(guī)定,在達(dá)成就業(yè)意向后,畢業(yè)生、用人單位、學(xué)校三方必須簽訂《全國普通高等學(xué)校畢業(yè)生就業(yè)協(xié)議書》。就業(yè)協(xié)議書是具有一定的廣泛性和權(quán)威性,是學(xué)校制訂就業(yè)方案派遣畢業(yè)生、用人單位申請用人指標(biāo)的主要依據(jù),對簽約的三方都有約束力。</p>
            <div class="center">
              <button>查看詳情</button><button>取消</button>
            </div>
          </div>


          示例2 - 刪除重復(fù)的代碼

          通常,您需要構(gòu)建一些不同的組件變體。相同的基本樣式,略有不同。讓我們使用一些顏色不同的按鈕。典型的解決方案是創(chuàng)建一個(gè)基類,比如.btn并添加變體類。

          .btn {
            border: 2px solid black;
          }
          .btn:hover {
            background: black;
          }
          .btn.red {
            border-color: red
          }
          .btn.red:hover {
            background: red
          }

          現(xiàn)在使用它們像這樣:

          <button class="btn">Hello</button>
          <button class="btn red">Hello</button>

          但是,這會添加一些代碼重復(fù)。在.red變體上,我們必須將border-color和background設(shè)置為紅色。

          這種情況可以使用CSS變量輕松修復(fù)。如下:

          CSS代碼:

          .btn{
            border-radius:4px;
            text-align:center;
            padding:.5em;
            margin-bottom:0.5em;
            background:#fff;
            border:1px solid var(--color, black);
          }
          .btn:hover{
            color:#fff;
            cursor:pointer;
            background:var(--color, black);
          }
          .btn.red{
            --color:red;
          }
          .btn.green{
            --color:green;
          }
          .btn.blue{
            --color:blue;
          }

          HTML代碼:

          <div class="btn">HMOE</div>
          <div class="btn red">HMOE</div>
          <div class="btn green">HMOE</div>
          <div class="btn blue">HMOE</div>

          示例3 - 使一些屬性可讀

          如果我們想要創(chuàng)建更復(fù)雜的屬性值的快捷方式,CSS vars非常適合使用,因此我們不必記住它。CSS屬性,如box-shadow,transform和font或其他帶有多個(gè)參數(shù)的CSS規(guī)則就是完美的例子。我們可以將屬性放在變量中,以便我們可以通過更易讀的格式重用它。

          例如:

          :root {
            --tiny-shadow: 4px 4px 2px 0 rgba(0, 0, 0, 0.8);
            --animate-right: translateX(20px);
          }
          li {
            box-shadow: var(--tiny-shadow);
          }
          li:hover {
            transform: var(--animate-right);
          }

          例4 - 級聯(lián)變量

          標(biāo)準(zhǔn)級聯(lián)規(guī)則也適用于CSS變量。因此,如果多次聲明自定義屬性,則css文件中最低的定義將覆蓋其上方的定義。下面的示例演示了動態(tài)操作用戶操作的屬性是多么容易,同時(shí)仍然保持代碼清晰簡潔。

          CSS_var.css文件:

          .orange-container {
            --main-text: 18px;
          }
          .orange-container:hover {
            --main-text: 22px;
          }
          .red-container:hover {
            --main-text: 26px;
          }
          .title {
            font-size: var(--title-text);
          }
          .content {
            font-size: var(--main-text);
          }
          .container:hover {
            --main-text: 18px;
          }

          base.css文件:

          * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
          }
          html {
            background: #eee;
            padding: 30px;
            font: 500 14px sans-serif;
            color: #333;
            line-height: 1.5;
          }
          .orange-container {
            background: orange;
          }
          .red-container {
            background: red;
          }
          .red-container,
          .orange-container {
            padding-top: 10px;
            padding-left: 50px;
          }
          .container {
            background: blue;
            padding: 20px;
            color: white;
          }
          p {
            transition: 0.4s;
          }
          .title {
            font-weight: bold;
          }

          index.html文件:

          <html>
          <head>
          <link rel="stylesheet" type="text/css" href="base.css">
          <link rel="stylesheet" type="text/css" href="css_vars.css">
          </head>
          <body>
          <div class="orange-container">
              Hover orange to make blue bigger.
              <div class="red-container">
                   Hover red to make blue even bigger.
                  <div class="container">
                      <p class="content">Hover on the different color areas to change the size of this text and the title.</p>
                  </div>
              </div>
          </div>
          </body>
          </html>

          示例5 - 具有CSS變量的主題切換器

          CSS變量的一個(gè)好處是它的反應(yīng)性。一旦我們更新它,任何具有CSS變量值的屬性也會更新。因此,只需幾行Javascript和CSS變量的智能使用,我們就可以制作一個(gè)主題切換器機(jī)制。

          例如:

          <!DOCTYPE html>
          <html>
              <head>
                  <meta charset="UTF-8">
                  <title>具有CSS變量的主題切換器</title>    
                  <style>
                      body {
                        background-color: var(--bg, #b3e5fc);
                        color: var(--bg-text, #37474f);
                        font-family: sans-serif;
                        line-height: 1.3;
                      }
                      .toolbar {
                        text-align: center;
                      }
                  </style>
              </head>
              <body>
                  <div class="toolbar">
                      <button value="dark">dark</button>
                      <button value="calm">calm</button>
                      <button value="light">light</button>
                  </div>
                  <h2>Stackoverflow Question</h2>
                  <p>I would like to use an external javascript file in another javascript file. For example, I could store all my global variables
                  in a globals.js file and then call then from the website logic logic.js. Then in the index.html, i would insert the tag.
                  How do I use the globals.js inside the logic.js?
                  </p>
                  <script>
                      var root = document.documentElement;
                      var themeBtns = document.querySelectorAll(".toolbar > button");
                      
                      themeBtns.forEach(function (btn){
                        btn.addEventListener("click", handleThemeUpdate);
                      });
                      
                      function handleThemeUpdate(e) {
                        switch (e.target.value) {
                          case "dark":
                            root.style.setProperty("--bg", "black");
                            root.style.setProperty("--bg-text", "white");
                            break;
                          case "calm":
                            root.style.setProperty("--bg", "#B3E5FC");
                            root.style.setProperty("--bg-text", "#37474F");
                            break;
                          case "light":
                            root.style.setProperty("--bg", "white");
                            root.style.setProperty("--bg-text", "black");
                            break;
                        }
                      }
                  </script>
              </body>
          </html>

          CSS變量的使用提示

          像CSS中幾乎所有的東西一樣,變量也非常簡單易用。以下是一些未包含在示例中的提示,但在某些情況下仍然非常有用:

          1)css變量區(qū)分大小寫。下面的示例是兩個(gè)不同的變量:

          :root { --color: blue; --COLOR: red; }

          2)當(dāng)您使用var()函數(shù)時(shí),您可以使用第二個(gè)參數(shù)。如果找不到自定義屬性,將使用第二個(gè)參數(shù)為默認(rèn)值:

          width: var(--custom-width, 50%);

          3)可以直接將CSS變量用于HTML:

          <!--HTML-->
          <html style="--size: 600px">
          <!--CSS-->
          body {
            max-width: var(--size)
          }

          4) 可以在其他CSS var中使用CSS變量:

          --base-red-color: #f00;
          --background-gradient: linear-gradient(to top, var(--base-red-color), #222);

          5) 可以使用媒體查詢使CSS變量成為條件。例如,以下代碼根據(jù)屏幕大小更改填充的值:

          :root {
              --padding: 15px 
          }
          @media screen and (min-width: 750px) {
              --padding: 30px
          }

          6) 不要害怕在 clac() 函數(shù)中使用CSS變量。

          --text-input-width: 5000px;
          max-width: calc(var(--text-input-width) / 2);

          當(dāng)然,CSS變量不是靈丹妙藥。不會解決你在CSS領(lǐng)域遇到的每一個(gè)問題。但是,使用它使您的代碼更具可讀性和可維護(hù)性。此外,它極大地改善了大型文檔的易變性。只需將所有常量設(shè)置在一個(gè)單獨(dú)的文件中,當(dāng)您只想對變量進(jìn)行更改時(shí),就不必跳過數(shù)千行代碼。


          主站蜘蛛池模板: 免费无码一区二区三区| 亚洲国产成人久久一区WWW | 精品无码人妻一区二区三区18| 精品国产亚洲一区二区在线观看 | 午夜性色一区二区三区免费不卡视频 | 成人中文字幕一区二区三区| 精品国产一区二区三区无码| 国产人妖在线观看一区二区| 中文字幕人妻AV一区二区| 亚洲一区在线视频观看| 在线中文字幕一区| 视频一区视频二区日韩专区| 日本在线电影一区二区三区| 成人一区二区三区视频在线观看| 亚洲国产一区在线| 国产色欲AV一区二区三区| 伊人色综合视频一区二区三区| 亚洲一区二区三区影院 | 丰满爆乳一区二区三区| 国产午夜精品一区二区三区不卡| 精品无码一区二区三区电影 | 国产一区视频在线| 91视频一区二区| 国产精品一区在线观看你懂的| 无码精品人妻一区二区三区人妻斩 | 国精品无码一区二区三区在线蜜臀| 国产AV一区二区精品凹凸| 免费视频精品一区二区| 国产丝袜美女一区二区三区| 国产精品成人免费一区二区| 日本精品少妇一区二区三区| 国产伦理一区二区| 日本片免费观看一区二区| 狠狠做深爱婷婷综合一区 | 国产一区二区久久久| 91福利视频一区| 国产一区二区三区不卡在线看| 国产精品熟女视频一区二区| 国产在线精品一区二区三区不卡| 久久国产三级无码一区二区| 亚洲日本一区二区|