召隆企博汇论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 843|回复: 0

小程序 如何在wxss中使用js里的变量?

[复制链接]

1

主题

3

回帖

144

积分

注册会员

Rank: 2

积分
144
发表于 2020-7-24 15:38:48 | 显示全部楼层 |阅读模式
本帖最后由 liwp 于 2020-7-27 12:07 编辑 ; I7 m3 S! \! s2 ~: }  D$ E6 z

7 d. K: C( p% s1 K1 c$ Zwxml:( H- W# L: Z2 t- i6 F& ~6 h
  1. <view class="comments_box" style="{{unfold?'max-height:'+GoodsInfo.reviewList.length*80+20+'rpx;':''}}">! D* p7 Q" }5 ?' m- D  I4 [
  2.     <view class="unfoldText" wx:if="{{GoodsInfo.reviewList.length>1}}" bindtap="clickUnfold">{{unfoldText}}</view>
    & o- [; ~, E& ]" ?7 w% T8 n8 I
  3.     <block wx:for="{{GoodsInfo.reviewList}}" wx:key='index'>
    - e! a3 }( l/ P9 _! O
  4.         <view class="comments_box_list" style='transition: transform 300ms linear 0ms;transform: translateY(-{{unfold?0:((GoodsInfo.reviewList.length<1)?(index==0?(1-GoodsInfo.reviewList.length)*30:(1-GoodsInfo.reviewList.length+index)*30):index*30)}}rpx);'>
    & B) z+ F5 @- O
  5.             <view class="comments_box_list_left">{{item.ReviewAppellation}}</view>6 ?2 R* C" \  x6 o2 l% P: B
  6.             <view class="comments_box_list_right">{{item.ReviewContent}}</view> ; |4 ?  R) t* f8 H3 q4 D, M4 B$ r
  7.         </view>
    & L6 V8 Q! K8 K
  8.     </block>
    5 z: W5 d) p8 L( s' j+ l
  9. </view>
复制代码
wxss:
. a$ S( ]! ?- [4 h# P% j
  1. .comments_box{
    ! l8 \8 N$ }( }6 l6 a5 N$ S. _& c
  2.   margin-top: 20rpx;
    . a, y: w3 b/ Y4 m! ?$ G: b( N
  3.   width: 100%;4 Y$ M4 \. x: H" y0 z' r
  4.   overflow: hidden;
    ) ^1 C$ [0 f- ?" l/ z
  5.   transition: max-height 0.5s;4 q0 H3 r. H9 n$ H8 o9 u% y: A) a
  6.   overflow: hidden;
    6 [4 i. ?2 U. k/ `3 x" N6 N
  7.   max-height: 105rpx;
    / V( }! h3 j, N# A1 F
  8. }
复制代码
我这里是使用动画来控制comments_box这个view的高度(max-height)变化时的过渡效果,我在wxss中给定固定值测试是可以实现效果的,但是因为这个view的高度是随数据变化的,所以我只能在wxml中通过GoodsInfo.reviewList的数组长度计算出高度之后赋值,结果测试后发现没有动画效果。
8 D" k, R3 N6 r. S所以我想在wxss中来使用GoodsInfo.reviewList的数组长度来计算高度,百度了一下,发现都是在wxml中使用的,跟我想要的不一样。6 b4 u% b- Q& e4 I8 a

9 q% ^- k  m1 _) B

8 A6 [* P3 A" B  D
0 @9 ?) B1 S" |' A2 @
: a4 I" }3 i& t+ p1 D: o0 z5 R
0 r- M3 s$ M+ ]" T! |* M
9 l0 @; U# M) K! b7 N1 H
. t  B  z5 @5 |! d: \- e
已解决:

5 A2 O5 {! ^/ T! ?$ y  C' }* }
在开发过程中,通常碰到样式非固定的情况,这时候就要使用变量来规定样式,例如,一个view的宽度需要使用变量:
1. 在wxss中,定义变量:width:var(--width--);
2. 在js中,定义变量:viewWidth,并给这个变量赋予想要的值
3. 在xml中,使用wxss中的变量和js中的变量:style="--width--: {{ viewWidth }}px"

# \& t# }: a. G2 n+ K! u( b
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|召隆企博汇 ( 粤ICP备14061395号 )

GMT+8, 2025-4-2 12:11 , Processed in 0.032667 second(s), 25 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表