首頁 web前端 css教學 css3中calc在less編譯時怎樣不被計算

css3中calc在less編譯時怎樣不被計算

Mar 20, 2018 pm 04:33 PM
css3 less sass

這次帶給大家css3中calc在less編譯時怎樣不被計算,css3中calc在less編譯時不被計算的注意事項有哪些,下面就是實戰案例,一起來看一下。

對於前端er來說,Less或Sass已經是一項必備的基本技能,有了這個利器,可以省下前端開發者的很多編碼時間,讓你寫CSS如行雲流水一般,然後最近我在Less裡加入calc時確發現了有點問題,我在Less中這麼寫:

p {width : calc(100% - 30px);}
登入後複製

結果Less把這個當成運算式去執行了,結果給我解析成這樣:

p {width: calc(70%);}
登入後複製

當時我就鬱悶了,怎麼會產生這樣的現象呢?後來各種查,是由於less的計算方式跟calc方法有重疊,兩者在一起有衝突,於是,我在Less中把calc的寫法改寫成下面這樣:

p {width : calc(~"100% - 30px");}
登入後複製

OK,解析結果正常: 

p {width: calc(100% - 30px);}
登入後複製

然而,把30px替換為一個變數,要怎麼寫呢?

  p {
  @diff : 30px;
  width : calc(~"100% - " + @diff);
  }
登入後複製

這麼寫Webstorm沒有報錯,但grunt-less報錯了:

C:\Users\zhong\WebstormProjects\test>grunt less

Running "less:development " (less) task

>> ParseError: Unrecognised input in style.less on line 4, column 2:

>> 3    @diff : 30px;

>> 4    width : calc(~"100% - " + @diff);

>> 5 }

Warning: E​​rror compiling style.less Use -- force to continue.

Aborted due to warnings.

於是這麼寫:

  p {
  @diff : 30px;
  width : calc(~"100% - " @diff);
  }
登入後複製

順利編譯過去,但Webstorm卻老是提示語法錯誤,雖然也能編譯但看著檔案有個錯誤提示心裡老

感覺不爽,找半天也沒發現Webstorm如何調試語法提示錯誤設定

於是,改成如下寫法:

  p {
  @diff : 30px;
  width : calc(~"100% - @{diff}");
  }
登入後複製

這種寫法又能編譯,Webstorm裡又不報錯,所以我比較喜歡用這種寫法,如此,便不會再有任何問題了。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

css3的動畫序列animation

#CSS怪異盒子模型和標準盒子模型如何使用

#

以上是css3中calc在less編譯時怎樣不被計算的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

純CSS3怎麼實現波浪效果? (程式碼範例) 純CSS3怎麼實現波浪效果? (程式碼範例) Jun 28, 2022 pm 01:39 PM

純CSS3怎麼實現波浪效果?這篇文章就來跟大家介紹一下使用 SVG 和 CSS 動畫來製作波浪效果的方法,希望對大家有幫助!

巧用CSS實現各種奇形怪狀按鈕(附代碼) 巧用CSS實現各種奇形怪狀按鈕(附代碼) Jul 19, 2022 am 11:28 AM

這篇文章帶大家看看怎麼使用 CSS 輕鬆實現高頻出現的各類奇形怪狀按鈕,希望對大家有幫助!

css怎麼隱藏元素但不佔空間 css怎麼隱藏元素但不佔空間 Jun 01, 2022 pm 07:15 PM

兩種方法:1、利用display屬性,只要為元素加上「display:none;」樣式即可。 2.利用position和top屬性設定元素絕對定位來隱藏元素,只需為元素加上「position:absolute;top:-9999px;」樣式。

css3怎麼實現花邊邊框 css3怎麼實現花邊邊框 Sep 16, 2022 pm 07:11 PM

在css中,可以利用border-image屬性來實作花邊邊框。 border-image屬性可以使用圖片來建立邊框,即給邊框加上背景圖片,只需要將背景圖片指定為花邊樣式即可;語法「border-image: url(圖片路徑) 向內偏移值圖像邊界寬度outset 是否重複;」。

sass軟體是什麼意思 sass軟體是什麼意思 Aug 15, 2022 am 11:39 AM

sass全名為“Software as a service”,意思是“軟體即服務”;它是一種軟體部署模式,第三方供應商在雲端基礎設施上建立應用程序,並以訂閱的形式,透過互聯網向客戶提供這些應用程序,不要求客戶預先建造底層基礎設施。這意味著軟體可以在任何有網路連線和網路瀏覽器的裝置上訪問,而不是像傳統軟體那樣只能在本機上安裝。

原來利用純CSS也能實現文字輪播與圖片輪播! 原來利用純CSS也能實現文字輪播與圖片輪播! Jun 10, 2022 pm 01:00 PM

怎麼製作文字輪播與圖片輪播?大家第一想到的是利用js,其實利用純CSS也能實現文字輪播與圖片輪播,下面來看看實作方法,希望對大家有幫助!

css3如何實現滑鼠點擊圖片放大 css3如何實現滑鼠點擊圖片放大 Apr 25, 2022 pm 04:52 PM

實作方法:1、使用「:active」選擇器選取滑鼠點擊圖片的狀態;2、使用transform屬性和scale()函數實現圖片放大效果,語法「img:active {transform: scale(x軸放大倍率,y軸放大倍率);}」。

css3怎麼設定動畫旋轉速度 css3怎麼設定動畫旋轉速度 Apr 28, 2022 pm 04:32 PM

在css3中,可以利用「animation-timing-function」屬性來設定動畫旋轉速度,該屬性用於指定動畫將如何完成一個週期,設定動畫的速度曲線,語法為「元素{animation-timing-function:速度屬性值;}」。

See all articles