闂傚倸鍊搁崐鎼佸磹閹间礁纾归柣鎴eГ閸ゅ嫰鏌ら崫銉︽毄濞寸姵姘ㄧ槐鎾诲磼濞嗘帒鍘$紓渚囧櫘閸ㄨ泛鐣疯ぐ鎺戠濞达絿鎳撴惔濠傗攽閻愭潙鐏﹂柣鐔濆懎濮柍褜鍓熷铏圭矙濞嗘儳鍓垫繝娈垮枔閸婃繈骞嗛崟顖f晬闁绘劕寮堕悗顒勬⒑閻熸澘鈷旂紒顕呭灦瀵煡骞栨担鍦弳闂佺粯娲栭崐鍦偓姘炬嫹
MYSQL婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繐霉閸忓吋缍戦柛銊ュ€块弻锝夊箻瀹曞洤鍝洪梺鍝勵儐閻楁鎹㈠☉銏犵闁绘劏鏅滈敍鍫濃攽閻愬弶鈻曞ù婊勭箞瀵煡骞撻幒婵堝數闁荤姾娅g亸銊ξ涘鑸电厱闁冲搫鍟禒杈ㄦ叏婵犲啯銇濇俊顐㈠暙閳藉顫濋澶嬫瘒闂傚倷鑳堕幊鎾诲床閺屻儺鏁勫璺猴功閺嗭附銇勯弽顐粶鐎瑰憡绻堥幃妤€鈽夊▎瀣窗闂佸憡锕╂禍婵堟崲濠靛顫呴柨婵嗘閵嗘劙姊虹紒姗嗘當婵☆偅绻傞悾宄扳攽閸♀晜鍍甸梺鐟板悁缁€浣圭妤e啯鈷掗柛顐ゅ枔閳藉绱掗妸銉吋闁哄瞼鍠栧畷娆撳Χ閸℃浼�
SQL闂傚倸鍊搁崐鎼佸磹瀹勬噴褰掑炊椤掑鏅悷婊冪Ч濠€渚€姊虹紒妯虹伇婵☆偄瀚板鍛婄瑹閳ь剟寮婚悢鍏尖拻閻庨潧澹婂Σ顕€姊虹粙鑳潶闁告柨閰i獮澶愬箹娴e憡顥濋柣鐘充航閸斿秴鈻撴ィ鍐┾拺婵懓娲ら悘鈺侇熆閻熷府韬€殿噮鍋婂畷鍫曨敆娴e搫骞楁繝娈垮枟椤ㄥ懎螞濡や胶顩叉繝濠傚幘閻熸壋鍫柛顐犲灮閺嗩偊姊洪崫鍕効缂傚秳鐒﹂幈銊╁焵椤掑嫭鐓忛柛顐g箖椤ョ偤姊哄▎鎯у籍闁哄矉缍佹慨鈧柍杞拌兌娴犫晠姊虹紒妯煎ⅹ闁靛牏枪椤曪絿鎷犲ù瀣潔濠碘槅鍨堕弨閬嶆倵鐠囨祴鏀介柣鎰级椤ョ偤鏌涢弮鈧ú鐔笺€侀弮鍫熸櫢闁跨噦鎷�
MYSQL闂傚倸鍊搁崐鎼佸磹瀹勬噴褰掑炊椤掑鏅悷婊冪Ч閿濈偛鈹戠€n偅娅囬梺绋跨焿婵″洨绮欒箛鏃傜瘈闁靛骏绲剧涵楣冩煠濞茶鐏︾€殿喗鎮傚畷濂稿煑閳轰椒澹曞Δ鐘靛仜閻忔繈宕濆鑸电厵鐎瑰嫰鍋婇崕蹇涙煏閸℃ê绗氱紒缁樼箓椤繈顢橀悩鎻掔疄闂備浇顕х换鎺楀磻濞戞瑦娅犲ù鐘差儏閻撯€愁熆鐠鸿櫣鐏辩痪鎯с偢閺屾盯骞橀懠顒夋М婵炲濞€娴滃爼寮婚敍鍕勃闁告挆鍕灡濠电姷顣槐鏇㈠礂濮椻偓閵嗕礁鈽夊Ο宄扮墯闂佸憡渚楅崰妤咁敊韫囨稒鈷掗柛灞剧懄缁佺増淇婂鐓庡婵炲棎鍨芥俊鑸靛緞婵犲嫷鍞甸梻浣芥硶閸o箓骞忛敓锟�
闂傚倸鍊搁崐鎼佸磹閹间礁纾归柣鎴eГ閸ゅ嫰鏌ら崫銉︽毄濞寸姵姘ㄧ槐鎾诲磼濞嗘帒鍘$紓渚囧櫘閸ㄨ泛鐣疯ぐ鎺戠濞达絿鎳撴惔濠傗攽閻愭潙鐏﹂柣鐔濆懎濮柍褜鍓熷铏圭矙濞嗘儳鍓垫繝娈垮枔閸婃繈骞嗛崟顖f晬闁绘劕寮堕悗顒勬⒑閻熸澘鈷旂紒顕呭灦瀵煡骞栨担鍦弳闂佺粯娲栭崐鍦偓姘炬嫹
闂傚倸鍊搁崐鎼佸磹閹间礁纾瑰瀣捣閻棗銆掑锝呬壕濡ょ姷鍋為悧鐘汇€侀弴銏℃櫆闁芥ê顦純鏇㈡⒒娴h櫣銆婇柛鎾寸箞閹柉顦归柟顖氱焸楠炴ḿ绱掑Ο琛″亾閸偆绠鹃柟瀵稿剱娴煎棝鏌熸潏鍓х暠闁活厽顨婇悡顐﹀炊閵娧€濮囬梺缁樻尵閸犳牠寮婚敓鐘茬闁靛ǹ鍎崑鎾诲传閵夛附娈伴梺鍓插亝濞叉﹢鍩涢幒妤佺厱閻忕偠顕ч埀顒佹礋閹﹢鏁冮崒娑氬幐闁诲繒鍋熼崑鎾剁矆閸愵亞纾肩紓浣贯缚濞插鈧娲栫紞濠囥€佸▎鎾村亗妤犵儐鍠撻崐鏍崲濠靛牆鏋堟俊顖氭惈閳峰姊虹紒妯诲皑闁逞屽墰缁烩偓缂傚倹姘ㄩ幉鎼佸棘閸柭も偓鍨€掑锝呬壕濠殿喖锕ㄥ▍锝囨閹烘嚦鐔煎即閻旈浠肩紓渚囧枛閿曨亪鐛鈧、娆撴嚃閳哄骞㈤梻鍌欒兌閹虫挻鏅堕悾灞藉灊妞ゆ牜鍋涚壕濠氭煕閺囥劌骞樼痪鎹愭闇夐柨婵嗘媼濞肩姵銇勮箛鎾跺⒈闁轰礁鍊块弻宥嗘姜閹峰矈鍞归梺琛″亾濞寸姴顑嗛悡鐔兼煙闁箑澧柍缁樻礋閺屾盯濡堕崶褎鐎婚梺瀹狀潐閸ㄥ潡銆佸☉妯锋婵炲棗绻愰弨顓熶繆閵堝洤啸闁稿绋撻幑銏狀潨閳ь剙顕i锕€绠荤紓浣股戝▍銏ゆ⒑鐠恒劌娅愰柟鍑ゆ嫹
闂傚倸鍊搁崐鎼佸磹閹间礁纾归柣鎴eГ閸ゅ嫰鏌涢锝嗙闁稿被鍔庨幉鎼佸籍閸惊銉╂煕閹般劍娅嗛柛搴e枛閺屾洝绠涚€n亞鍔村┑鐐跺皺鏋柍瑙勫灴閹晝鎷犺娴兼劙鏌f惔銏犲毈闁告瑥鍟悾鐑芥晲閸垻鏉稿┑鐐村灦閻熝囧储閹剧粯鈷戦柛娑橈功缁犳捇鎮楀鐓庡⒋闁糕斁鍋撳銈嗗坊閸嬫捇鏌熼懞銉х煀闁宠閰f慨鈧柕鍫濇閳ь剛鍏橀弻锝夊箣閻愩劎绱伴梺鍛婏耿娴滆泛顫忓ú顏咁棃婵炴垼椴搁埢鎾绘⒑閹肩偛濡藉┑鐐诧躬楠炲啯銈i崘鈺冨姸閻庡箍鍎卞Λ娑㈠储閸涘﹦绠鹃弶鍫濆⒔閸掔増绻濋埀顒勬焼瀹ュ棗鍓归梺鍦劋椤ㄥ棝鎮″☉銏″€堕柣鎰邦杺閸ゆ瑥鈹戦垾鐐藉仮闁哄苯绉归幐濠冨緞濡亶锕傛煣娴兼瑧绉柡灞剧洴閳ワ箓骞嬪┑鍥╁蒋濠电偛顕崢褔宕弶鎴綎缂備焦蓱婵潙顪冪€n亞鍑归悷鏇炴缁辨捇宕掑姣欙繝鏌ら崘鎻掝暢闁告帗甯楃换婵嗩潩椤掆偓閸炪劑鎮峰⿰鍕煉鐎规洜鏁诲鎾偄缂堢姷鐩庨梻浣告惈閸燁偊宕愰崨濠勵洸闁告挆鈧崑鎾舵喆閸曨剛顦ュ銈忓瘜閸ㄨ埖淇婇幘顔肩闁规惌鍘介崓鐢告⒑缂佹ɑ灏繛鎾敱缁傛帡顢橀姀锛勫幐閻庡箍鍎扮拋鏌ュ磻閹捐妫橀柕澶涢檮閺夋悂姊绘担铏瑰笡闁告梹娲栬灒濠电姴娲ら崥褰掓煟閺傝法娈遍柡鈧懞銉d簻闁哄秲鍔庨埊鏇㈡倶韫囥儵妾い銊e劦閹瑩鎳犻鍌ゅ晪闂備浇妗ㄩ悞锕傚箲閸ヮ剙鏋侀柟鍓х帛閺呮悂鏌ㄩ悤鍌涘
闂傚倸鍊搁崐鎼佸磹瀹勬噴褰掑炊瑜忛弳锕傛煕椤垵浜濋柛娆忕箳閳ь剝顫夊ú鏍洪敂钘夊灁濠靛倸鎲¢悡娑㈡倶閻愰鍤欓柛鏃€宀搁弻锝夊Χ閸パ傚缂備胶绮惄顖氱暦閸楃倣鐔兼惞闁稒鍋呯紓鍌氬€风拋鏌ュ磻閹炬枼鏀介柣妯诲絻閺嗙偤鏌涘▎蹇曠濞e洤锕幃娆愶紣濠靛棙顔勫┑鐐茬摠缁挾绮婚弽褜娼栭柧蹇氼潐鐎氭岸鏌嶉妷銉э紞濞寸姭鏅犲娲传閵夈儲鐎惧┑鐐插悑閻熲晠骞冩ィ鍐╁€婚柤鎭掑劚娴滄粎绱掗悙顒€顎滃瀛樻倐瀵煡濮€閿涘嫮顔曢柡澶婄墕婢х晫绮旈浣典簻闁哄洨鍠撴晶鐢碘偓瑙勬处閸ㄥ爼宕洪埀顒併亜閹烘垵顏柍閿嬪浮閺屾稓浠﹂崜褎鍣梺绋跨箰閺堫剟濡甸崟顖氼潊闁绘瑥鎳撻崥顐㈩渻閵堝啫鐏€光偓缁嬫鍤曞ù鐘差儛閺佸洭鏌i幇顔芥毄鐎规洝鍩栫换婵嗩嚗闁垮绶查柍褜鍓氶崝娆忕暦閹达箑绠绘繛锝庡厸缁ㄥ姊虹€圭姵銆冮梻鍕Ч瀹曟垿濮€閳垛晛浜鹃悷娆忓缁€鈧梺闈涚墛閹倿鐛崘顔碱潊闁靛繆鈧厖绮ч梻浣规灱閺呮盯宕悧鍫㈩洸婵炲棙鎸婚埛鎴︽偣閸ャ劎鍙€妞ゅ孩顨堢槐鎺楁偐閼碱儷褏鈧娲樺ú妯横缚韫囨稑鐓橀柟顖嗗倸顥氭繝娈垮枟宀e潡宕㈣閻涱喖螖閸愵亞锛滈柣搴秵娴滆泛螣閳ь剚绻濆▓鍨灀闁稿鎹囧铏圭磼濡吋鍠涢梺绋款儐閹瑰洭寮婚敐澶婃闁圭ǹ瀵掑Λ锕傛⒑鐠団€虫灕妞ゎ偄顦甸獮蹇涘川椤栨粓鈹忛柣搴秵閸嬪棛绮旈悜鑺モ拺閻犲洦褰冮銏ゆ煟閺冩垵澧存鐐茬箻閺佹捇鏁撻敓锟�

微信小程序实战项目富文本编辑器实现-小程序开发

首页 2024-07-09 07:33:40

本文为您带来了微信applet的相关知识,主要介绍了富文本编辑器的实践示例,包括创建发布页面、实现基本布局、实现编辑区操作栏功能等。让我们看看。我希望它能对你有所帮助。

【相关学习推荐:小程序学习教程】

1. 实现效果

效果如下图所示:

实现的功能点如下:

  • 文本加粗,斜体,下划线,对齐方法
  • 取消、恢复、插入图片、删除功能。
2. 创建发布页面,实现基本布局

首先创建发布页面 article,在 app.json 页面可以通过配置生成。

"pages": [
        "pages/article/article"
    ]

article.wxml 中、书写结构:

<view>
  <!-- 文章类型 -->
  <view>
    <picker bindchange="bindPickerChange" model:value="{{index}}" range="{{array}}">
      <view class="picker">
        文章类型:{{objectArray[index].name}}
      </view>
    </picker>
  </view>
  <!-- 文章标题 -->
  <view>
    <input name="title" class="title" placeholder="请输入文章标题" maxlength="18" model:value="{{title}}"></input>
  </view>
  <!-- 编辑区 -->
  <view class="container">
    <view class="page-body">
      <view class=&#39;wrapper&#39;>
        <!-- 操作栏 -->
        <view class=&#39;toolbar&#39; bindtap="format">
           <i class="iconfont icon-zitijiacu"></i>
          <i class="iconfont icon-zitixieti"></i>
          <i class="iconfont icon-zitixiahuaxian"></i>
          <i class="iconfont icon-zuoduiqi"></i>
          <i class="iconfont icon-juzhongduiqi"></i>
          <i class="iconfont icon-youduiqi"></i>
          <i class="iconfont icon-undo"></i>
          <i class="iconfont icon-redo"></i> 
          <i class="iconfont icon-charutupian"></i>
          <i class="iconfont icon-shanchu"></i>

        </view>
        <!-- 文章内容区,富文本编辑器 -->
        <editor id="editor" class="ql-container" placeholder="{{placeholder}}"  showImgSize showImgToolbar showImgResize>
        </editor>
        <!-- 发布按钮 -->
        <view class="button" bindtap="formSubmit">发布</view>
      </view>
    </view>
  </view>
</view>

article.wxss,写作的基本风格:

page{
    width: 740rpx;
    margin: 0 auto;
    background-color: #f9f9f9;

}

.title {
  border: 1rpx solid #f2f2f2;
  margin: 10rpx;
  height: 70rpx;
  line-height: 70rpx;
  border-radius: 10rpx;
}

.picker{
  padding: 10rpx;
}

.wrapper {
  padding: 5px;
}

.iconfont {
  display: inline-block;
  padding: 8px 8px;
  width: 24px;
  height: 24px;
  cursor: pointer;
  font-size: 20px;
}

.toolbar {
  box-sizing: border-box;
  border-bottom: 0;
  font-family: &#39;Helvetica Neue&#39;, &#39;Helvetica&#39;, &#39;Arial&#39;, sans-serif;
}

.ql-container {
  box-sizing: border-box;
  padding: 12px 15px;
  width: 100%;
  min-height: 30vh;
  height: auto;
  background: #fff;
  margin-top: 20px;
  font-size: 16px;
  line-height: 1.5;
  border: 1rpx solid #f2f2f2;
  border-radius: 15rpx;
}

.button{
  width: 360rpx;
  height: 80rpx;
  line-height: 80rpx;
  text-align: center;
  margin: auto;
  margin-top: 50rpx;
  border-radius: 8rpx;
  font-size: 32rpx;
  color: white;
  background-color: #497749!important;
}

此时,我们会发现中间的操作栏图标没有显示,我们需要 article.wxss 中头部引入 iconfont.wxss 字体图标。 iconfont.wxss 获取文件地址

@import "./assets/iconfont.wxss";
3. 实现编辑区操作栏的功能

本文只实现操作栏的功能,实现富文本编辑,其他文章类型的选择,请自行实现,不难哦!

首先,我们需要获得富文本编辑器的例子 EditorContext,通过 wx.createSelectorQuery 获取,我们在页面上 Page 在函数中,创建 onEditorReady 用于获取此示例的函数:

    onEditorReady() {
        const that = this
        wx.createSelectorQuery().select(&#39;#editor&#39;).context(function (res) {
            that.editorCtx = res.context
        }).exec()
    }

然后将该方法绑定到富文本编辑器中 bindready 在属性方面,随着富文本编辑器初始化后的触发,从而获得实例。

<editor id="editor" 
class="ql-container" 
placeholder="{{placeholder}}"  
showImgSize 
showImgToolbar 
showImgResize 
bindstatuschange="onStatusChange" 
read-only="{{readOnly}}" 
bindready="onEditorReady">
3.1. 实现文本加粗、斜体、文本下划线、左对齐、中对齐、右对齐

如何修改文本样式?

  • 通过 EditorContext 实例提供的API:EditorContext.format(string name, string value),修改样式。
  • name:CSS属性;value:值。

通过查阅微信小程序开发文档,我们可以实现我们需要的上述功能 name 和 value的值为:

那么我们如何通过点击按钮来修改文本样式呢?
  • 首先,我们在图标中 将name绑定到标签上 和 value 填写图标对应上图的属性 name 和 value,无 value 不填就够了。
  • 然后在父亲的标签上绑定事件 format,通过事件函数使用 EditorContext.format API 修改样式。
        <view class=&#39;toolbar&#39; bindtap="format">
          <i class="iconfont icon-zitijiacu  data-name="bold"></i>
          <i class="iconfont icon-zitixieti data-name="italic"></i>
          <i class="iconfont icon-zitixiahuaxian  data-name="underline"></i>
          <i class="iconfont icon-zuoduiqi  data-name="align" data-value="left"></i>
          <i class="iconfont icon-juzhongduiqi  data-name="align" data-value="center"></i>
          <i class="iconfont icon-youduiqi data-name="align" data-value="right"></i>
        </view>

Page 函数中的 format 函数:

    format(e) {
        let {
            name,
            value
        } = e.target.dataset
        if (!name) return
        this.editorCtx.format(name, value)
    },

问题:当我们点击图标时,我们改变了文本风格,但图标风格没有改变,不能提示我们文本的当前风格状态,那么如何解决呢?

  • 此时,我们需要动态地改变字体图标的样式,比如点击图标后改变颜色。

通过查阅 editor 微信小程序开发相关文档后,bindstatuschange 当你通过属性绑定时,属性绑定的方法就会出现。 Context 当方法改变编辑器内部样式时,触发将返回选区设置的样式。

所以我们可以在那里 data 中,添加 formats 对象,存储点击后的样式属性。然后点击图标按钮,通过 bindstatuschange 将绑定方法存储在设定的样式中 formats 中间;模板渲染时,class 属性,添加 {{formats.align === 'right' ? 'ql-active' : ''}}(如文本向右),当您点击此图标时, formats 有这个属性,然后添加我们的动态类名 ql-active 改变图标颜色。

具体实现

  • editor 标签属性 bindstatuschange 绑定方法 onStatusChange
<editor id="editor" 
class="ql-container" 
placeholder="{{placeholder}}"  
showImgSize showImgToolbar showImgResize  
bindstatuschange="onStatusChange" 
read-only="{{readOnly}}" 
bindready="onEditorReady">
    onStatusChange(e) {
        const formats = e.detail
        this.setData({
            formats
        })
    }
  • 在图标 在标签上,添加{{formats.align === 'right' ? 'ql-active' : ''}}
          <i class="iconfont icon-zitijiacu {{formats.bold ? &#39;ql-active&#39; : &#39;&#39;}}" data-name="bold"></i>
          <i class="iconfont icon-zitixieti {{formats.italic ? &#39;ql-active&#39; : &#39;&#39;}}" data-name="italic"></i>
          <i class="iconfont icon-zitixiahuaxian {{formats.underline ? &#39;ql-active&#39; : &#39;&#39;}}" data-name="underline"></i>
          <i class="iconfont icon-zuoduiqi {{formats.align === &#39;left&#39; ? &#39;ql-active&#39; : &#39;&#39;}}" data-name="align" data-value="left"></i>
          <i class="iconfont icon-juzhongduiqi {{formats.align === &#39;center&#39; ? &#39;ql-active&#39; : &#39;&#39;}}" data-name="align" data-value="center"></i>
          <i class="iconfont icon-youduiqi {{formats.align === &#39;right&#39; ? &#39;ql-active&#39; : &#39;&#39;}}" data-name="align" data-value="right"></i>
  • article.wxss 添加 ql-active
.ql-active {
  color: #497749;
}
3.2. 取消、恢复、插入图片、删除操作

首先在 将相应事件绑定到标签上:

          <i class="iconfont icon-undo" bindtap="undo"></i>
          <i class="iconfont icon-redo" bindtap="redo"></i> 
          <i class="iconfont icon-charutupian" bindtap="insertImage"></i>
          <i class="iconfont icon-shanchu" bindtap="clear"></i>

撤销 undo

调用 EditorContext API 即可

    undo() {
        this.editorCtx.undo()
    }

恢复 redo

同理

    redo() {
        this.editorCtx.redo()
    }

插入图片 insertImage

同理

    insertImage() {
        const that = this
        wx.chooseImage({
            count: 1,
            success: function (res) {
                wx.showLoading({
                    title: &#39;图片正在上传&#39;,
                })
                wx.cloud.uploadFile({
                    cloudPath: `news/upload/${time.formatTime(new Date)}/${Math.floor(Math.random() * 100000000)}.png`, // 上传到云端的路径
                    filePath: res.tempFilePaths[0], 
                    success: cover => {
                        that.editorCtx.insertImage({
                            src: cover.fileID,
                            data: {
                                id: cover.fileID,
                                role: &#39;god&#39;
                            },
                            success: function () {
                                wx.hideLoading()
                            }
                        })
                    }
                })
            }
        })
    }

清空 clear

同理

    clear() {
        this.editorCtx.clear({
            success: function (res) {
                console.log("clear success")
            }
        })
    }

【相关学习建议:小程序学习教程】

以上是微信小程序实战项目富文本编辑器实现的详细内容,请关注其他相关文章!


p
SEO闂傚倸鍊搁崐鎼佸磹妞嬪海鐭嗗ù锝堟缁€濠傗攽閻樻彃鈧绱撳杈ㄥ枑闊洦娲橀~鏇㈡煟閹邦剦鍤熺紒鈾€鍋撻梻浣规偠閸庢粓宕堕…鎺旇埞婵犵數濮烽弫鎼佸磻濞戞鐔哥節閸愵亶娲稿┑鐘诧工閻楀﹦鈧艾鎳橀弻锝夊棘閸喗鍊梺缁樻尪閸庣敻寮婚敐澶婂嵆闁绘劖绁撮崑鎾诲捶椤撴稑浜炬慨妯煎亾鐎氾拷
闂傚倸鍊搁崐鎼佸磹妞嬪海鐭嗗〒姘e亾妤犵偞鐗犻、鏇㈡晜閽樺缃曢梻浣虹《閸撴繈鎮疯閹矂骞樼紒妯衡偓鍨箾閹寸儐浼嗛柟杈剧畱閻鐓崶銊р姇闁绘挾鍠栭弻锟犲礃閵娿儮鍋撻崫銉︽殰闁割偅娲橀埛鎺楁煕鐏炶鈧洟鎮橀敃鍌涚厸閻忕偟鍋撶粈鍐磼缂佹ḿ顬兼い锔界叀閺岋繝宕奸銏犫拫閻庤娲滄繛鈧柟顔规櫇缁辨帒螣闁垮顏瑰┑鐘垫暩閸嬬姷浜稿▎鎴濆灊妞ゆ牗绮嶉鑺ョ箾閹存瑥鐏柣鎾寸懇閺屾盯骞嬪▎蹇婂亾閺嶎偀鍋撳鐐
闂傚倸鍊搁崐椋庣矆娓氣偓楠炴牠顢曚綅閸ヮ剦鏁冮柨鏇楀亾闁汇倗鍋撶换婵囩節閸屾稑娅i梺鎼炲妽缁诲牓鐛弽顬ュ酣顢楅埀顒佷繆婵傚憡鐓熼柟鎯ь嚟缁犳捇鏌嶇憴鍕伌鐎规洘甯掗埞鍐箻閾忣偉纭€闂侀€炲苯澧柤褰掔畺钘濋梺顒€绉撮悞鍨亜閹哄棗浜剧紓浣哄Т缁夌懓鐣烽弴銏$劶鐎广儱鎳愰悿鍥煙閸忓吋鍎楅柣鎾愁槺缁辩偤寮介鐔哄帾闂佸壊鍋呯换宥呂hぐ鎺撶厽闁规儳鐡ㄧ粈瀣煛鐏炶濡奸柍瑙勫灴瀹曞崬螖娴h鍞叉繝鐢靛Х椤d粙宕滃┑瀣畺闁稿瞼鍋涢拑鐔衡偓骞垮劚閻楁粌顬婇妸鈺傗拺缂佸娉曠粻鑼磼鐎n偄鐏存繝鈧笟鈧娲箹閻愭彃濮夐梺鍝勬噺缁矂鎮鹃悜钘夌煑濠㈣泛鐬奸鏇㈡⒑缁洖澧查柨姘舵煟韫囧﹥娅婇柡宀嬬秮椤㈡﹢鎮㈤悜妯烘珣闂備礁鐤囬~澶愬垂閸фぜ鈧礁鈽夊Ο婊勬閸┾偓妞ゆ帊鑳堕々鑼磽瀹ュ洤鐦查梻鍌氬€峰ù鍥敋瑜嶉~婵嬫晝閸岋妇绋忔繝銏e煐閸旀洜绮婚弽顓熺厱妞ゆ劧绲剧粈鈧紒鐐劤濞尖€愁潖濞差亶鏁嗛柍褜鍓涚划鏃堝箻椤旇棄鍓瑰┑掳鍊曢幊蹇涙偂閵夆晜鐓熼柡鍥╁仜閳ь剙婀遍埀顒佺啲閹凤拷
濠电姷鏁告慨鐑藉极閹间礁纾婚柣鎰惈閸ㄥ倿鏌涢锝嗙缂佺姳鍗抽弻鐔虹磼閵忕姵鐏堢紒鐐劤椤兘寮婚悢鐓庣鐟滃繒鏁☉銏$厓闂佸灝顑呴悘锔剧磼缂佹ḿ娲寸€规洖宕灒闁告繂瀚闂傚倷绀侀幖顐︻敄閸℃稒鍋¢柍鍝勬噹閽冪喖鏌i弬鎸庢喐闁荤喎缍婇弻娑⑩€﹂幋婵囩亪濡炪値鍋勫ú顓㈠箖濡も偓閳绘捇宕归鐣屼簴闂備礁鎲¢弻銊︻殽閹间礁鐓″鑸靛姈閸嬨劎绱掔€n亞浠㈢紒鎰☉椤啴濡堕崱娆忣潷缂備緡鍠氭繛鈧€规洦鍨伴悾婵嬪焵椤掑倹顫曢柟鎹愵嚙绾惧吋绻涢崱妯虹劸婵″樊鍠栭—鍐Χ閸℃浠撮梺纭呮珪閿曘垽濡存笟鈧浠嬵敇閻愰潧鈧偛顪冮妶鍡楃瑨妞わ缚鍗冲鎻掆堪閸愮偓瀵岄梺闈涚墕濡绮幒妤佸€垫慨妯煎帶婢ф挳鏌熼姘冲閾绘牠鏌涘☉鍗炴灓闁告瑥妫濆铏圭磼濡崵顦ラ梺绋匡工濠€閬嶅焵椤掍胶鍟查柟鍑ゆ嫹
C闂傚倸鍊搁崐鎼佸磹閻戣姤鍤勯柛顐f礀绾惧潡鏌i姀鈶跺綊鎮块悙顒傜瘈濠电姴鍊搁弳鐔割殽閻愬瓨宕岄柡灞剧椤﹁櫕銇勯妸銉﹀殗鐎规洖缍婂畷鎺楁倷閼碱剦鍟囬梺鍝勵槸閻楀棙鏅舵禒瀣畺闁稿繘妫跨换鍡樸亜閹伴潧浜滈柣蹇ョ節閺屾洟宕惰椤忣厽銇勯姀鈩冪妞ゃ垺娲熸慨鈧柨娑樺婢规洜绱撻崒姘偓椋庢媼閺屻儱纾婚柟鐐墯閻斿棝鎮规潪鎷岊劅闁稿孩鍨圭槐鎺楁偐閼姐倗鏆梺鍝勭灱閸犳牠鐛幋锕€绠涙い鎾跺Т濞懷囨⒒娓氣偓濞艰崵寰婇懖鈺佸灊婵炲棙鎸搁拑鐔兼煟閺冨倵鎷¢柡浣革功閻ヮ亪顢橀悙鍙壭╂繛鏉戝悑閸旀洟鈥旈崘顔嘉ч柛鈩冡缚閸欏棛绱撴担铏瑰笡閽冨崬菐閸パ嶈含闁诡喗绮撻幐濠冪珶閳瑰灝濮傞柡灞炬礃瀵板嫰宕煎┑鍡椥戞繝纰樻閸ㄤ粙骞忛敓锟�