Swift 讓屬性字簡單點盾沫、再簡單點以及屬性字點擊

屬性字是什么

就是帶有屬性的字符串病附,可以為整個字符串添加各種格式效果等也可以為部分添加沸毁。

如果使用

使用 NSAttributedString 或者 NSMutableAttributedString 來構建一個屬性字對象
這兩兄弟的區(qū)別是NSAttributedString一旦完成初始化就不能再后續(xù)中更改各種屬性了峰髓。NSMutableAttributedString可以傻寂,后者標識可變的

為什么要用

屬性字是我們平時開發(fā)普遍的不能再普遍的需求,設計為了好看或者強調某幾個文字就會對一行文字中的幾個或者幾段使用不同的字體儿普、顏色,有的還要使用下劃線掷倔,中劃線等眉孩,有的為了表示這里很特殊,會加一個小圖標表示疑問 警告 或者其他提示性含義

為什么要簡單點

系統(tǒng)屬性字的用法真的很麻煩勒葱,而且也不好記浪汪,有些難記的總是在使用的時候還要去查,而且按照下標去數(shù)第幾個然后去賦值屬性簡直很low凛虽,代碼又寫一大堆難于維護死遭。

記得之前有寫過一篇文章 Swift 屬性字怎么玩,當時對屬性字的幾個簡單的屬性進行了封裝,并自定義了一個操作符凯旋,用鏈式加函數(shù)式的方式去寫屬性字呀潭,覺得很酷,但是那個東西并不完善至非,而且也不夠簡單钠署,而且函數(shù)式和自定義操作符也完全沒必要。所以就寫了個比較完善和實用的荒椭。

有哪些功能

目前支持以下功能谐鼎,日常項目中使用的功能基本覆蓋。

  • 字體
  • 文字顏色
  • 背景色
  • 下劃線
  • 下劃線顏色
  • 行間距
  • 文字間距
  • 描邊顏色
  • 描邊寬度
  • 中劃線
  • 中劃線顏色
  • 設置圖片

怎么使用

當然要使用起來非常的簡單趣惠,再簡單了狸棍。純鏈式調用, + 號連接不同屬性字 味悄。圖片可以調整位置大小草戈。如果要給整段為本加屬性比如行間距等,也可以用括號括起來侍瑟,支持括號運算猾瘸。

示例
label1.attributedText = "屬性字"
      .attribute()
      .fontSize(18)
      .foreColor(UIColor.blue)
      .underLine(.styleSingle)
      .underLineColor(UIColor.black)
      +
      (
      " 測試一下"
        .attribute()
        .font(UIFont.boldSystemFont(ofSize: 20))
        .foreColor(UIColor.red)
        .underLine(.styleDouble)
        .underLineColor(UIColor.blue)
      +
      " ¥".attribute()
        .font(UIFont.boldSystemFont(ofSize: 23))
        .foreColor(UIColor.black)
      ).lineSpace(5)
      +
      " 2000"
        .attribute()
        .fontSize(19)
        .foreColor(UIColor.purple)
        .backgroundColor(UIColor.lightGray)
        .fontSpace(3.5)
      +
      " 描邊文字"
        .attribute()
        .fontSize(19)
        .strokeColor(UIColor.blue)
        .strokeWidth(3)
      +
      " 中劃線 "
        .attribute()
        .fontSize(17)
        .strike(2)
        .strikeColor(UIColor.darkGray)
      +
      "帶圖片提示的文本"
        .attribute()
        .fontSize(15).foreColor(UIColor.lightGray)
        .picture( UIImage(named: "warning"), bounds: CGRect(x: 0, y: 0, width: 13, height: 13), index: 0)

源碼就鏈兩個Extension,非常的簡單粗暴丢习。但是用起來也是非常的舒服

屬性字點擊

我們經(jīng)常會需要在一段提示的某幾個文字上加上點擊事件牵触,要么跳轉頁面,要么彈出提示咐低,并非識別連接或者@someone揽思, 微信聊天中經(jīng)常會提示,帶有藍色可點擊文字见擦。

但是這個普普通通的需求钉汗,卻并不好實現(xiàn)羹令,系統(tǒng)的TextView可以自定識別連接和電話號碼但是不能識別自定義的屬性字。

so 损痰, 這里我們也實現(xiàn)了一個可以很easy的使用給屬性字加點擊事件的TextView --- EZTextView

來看一下效果福侈。

示例

使用方法依舊是鏈式調用,記得先remove

textView
      .removeAllAttribute()
      .appendAttributedText("溫馨提示卢未,謹防詐騙肪凛,跟您對話的可能是個騙子!A缮纭伟墙! "
        .attribute()
        .foreColor(UIColor.gray)
        .fontSize(15)
        .toEz())
      .appendAttributedText(" 拉黑 ".attribute()
        .foreColor(UIColor.blue)
        .font(UIFont.boldSystemFont(ofSize: 17))
        .toEz()
        .addAction{
          print("------這里是拉黑系統(tǒng)---------")
      })
      .appendAttributedText(" 舉報 ".attribute()
        .foreColor(UIColor.blue)
        .font(UIFont.boldSystemFont(ofSize: 17))
        .toEz()
        .addAction{
          print("------這里是舉報系統(tǒng)---------")
      })

因為是文本顯示所以最好先設置下屬性

textView.isEditable = false
textView.isScrollEnabled = false

這樣,以后再也不用擔心文字里那塊需要點擊了滴铅。

如何引入

GitHub 連接: https://github.com/smalldu/EasyAtrribute

支持cocoaPods

備注

一個非常輕量的小工具類~ 希望大家可以喜歡

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末戳葵,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子汉匙,更是在濱河造成了極大的恐慌拱烁,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件噩翠,死亡現(xiàn)場離奇詭異邻梆,居然都是意外死亡,警方通過查閱死者的電腦和手機绎秒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進店門浦妄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人见芹,你說我怎么就攤上這事剂娄。” “怎么了玄呛?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵阅懦,是天一觀的道長。 經(jīng)常有香客問我徘铝,道長耳胎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任惕它,我火速辦了婚禮怕午,結果婚禮上,老公的妹妹穿的比我還像新娘淹魄。我一直安慰自己郁惜,他們只是感情好,可當我...
    茶點故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布甲锡。 她就那樣靜靜地躺著兆蕉,像睡著了一般羽戒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上虎韵,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天易稠,我揣著相機與錄音,去河邊找鬼包蓝。 笑死驶社,一個胖子當著我的面吹牛,可吹牛的內容都是我干的养晋。 我是一名探鬼主播衬吆,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼梁钾,長吁一口氣:“原來是場噩夢啊……” “哼绳泉!你這毒婦竟也來了?” 一聲冷哼從身側響起姆泻,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤零酪,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后拇勃,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體四苇,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年方咆,在試婚紗的時候發(fā)現(xiàn)自己被綠了月腋。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,427評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡瓣赂,死狀恐怖榆骚,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情煌集,我是刑警寧澤妓肢,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站苫纤,受9級特大地震影響碉钠,放射性物質發(fā)生泄漏。R本人自食惡果不足惜卷拘,卻給世界環(huán)境...
    茶點故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一喊废、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧栗弟,春花似錦操禀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽斤寂。三九已至,卻和暖如春揪惦,著一層夾襖步出監(jiān)牢的瞬間遍搞,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工器腋, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留溪猿,地道東北人。 一個月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓纫塌,卻偏偏與公主長得像诊县,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子措左,可洞房花燭夜當晚...
    茶點故事閱讀 45,440評論 2 359

推薦閱讀更多精彩內容