首先把那个文字框view设置一个固定的高度(比如3行),overflow属性设为hidden,position属性设为relative。
“”和“展开”放在同一个绝对定位(position为absolute)的view内,放在文字框内,定位在右下角,文字大小与文字框一致,这样当这个层显示时,就自然覆盖了文字框右下角,形成“ 展开”的效果。
然后在js中计算文字简介的字数,再根据文字框的字体宽度计算出总长度,除以文字框的宽度,如果计算结果大于3,就说明溢出了。这时可以通过setData通知wxml显示“ 展开”。
给“ 展开”绑定tap事件,点击后文字框的高度变为auto,这样溢出的部分就重新出现了,当然这时候要再次把“ 展开”隐藏。
小程序里面现有打开摄像头的方式有两种:
1、API调用,这个API可以设置直接打开相机,但不能打开的时候默认为前置摄像头。
2、小程序camera组件,camera组件可以设置device-position为front默认就是前置摄像头,但这个是一个原生组件,小程序原生组件层级默认为最大,设置z-index都无法覆盖(原生组件使用限制: >
微信小程序自带的API中的页面交互功能,虽然提示功能非常全面,但是所有的交互API中是没有可以自己在提示框中输入文本的功能,那么现在我们来自己做这样的一个提示框(可以带有输入功能),在提示框输入完内容之后,点击确定,可以将文本内容返回,点击取消则可以回到之前的状态。
(在这里,主页面的布局可以根据每个人的想法来布局,这里展示的css之后展示提示框部分的)
1、首先打开微信开发者工具,建立一个代码模板,那么我们这个提示框就是写在这个页面上。
这里我们主页面叫做index
2、在基本页面中写上一个姓名的文本,当前姓名用<text>{{stuName}}</text>表示,然后为一个button按钮,再在js文件中,建立相应的点击事件以及stuName的信息。这样,一个原始页面就写好了。
下面我们开始d出框页面的制作
<view class='toast-box' hidden='{{!ifName}}'>
<view class='toastbg'></view>
<view class='showToast'>
<view class='toast-title'>
<text>修改姓名</text>
</view>
<view class='toast-main'>
<view class='toast-input'>
<input placeholder='请输入姓名' bindinput='setValue' data-name='stuEidtName'></input>
</view>
</view>
<view class='toast-button'>
<view class='button1'>
<button catchtap='cancel'>取消</button>
</view>
<view class='button2'>
<button catchtap='confirm'>确定</button>
</view>
</view>
</view>
</view>
3、我们可以发现,点击按钮后d出输入框,如果点击除取消和确定之外的地方,是不会有反应的。为了做到这个功能,我们用一个绝对位置的渲染层(toastbg),覆盖住整个页面,并且如果你的页面长度没有滚动的话,请输入min—height:100vh,如果页面发生滚动,请把长度控制在height:100%即可看到整个页面都被覆盖。并且这个覆盖的页面要表现为透明,opacity:02,即可
4、bindinput为写文本时所触发的事件,data-name为文本数据所保存的地方,在js中我们可以把这个数据打印出来,会发现我们所输入的文本信息。
以下为css的代码
toast-box {
width: 100%;
height: 100%;
opacity: 1;
position: fixed;
top: 0px;
left: 0px;
}
toastbg {
opacity: 02;
background-color: black;
position: absolute;
width: 100%;
min-height: 100vh;
}
showToast {
position: absolute;
opacity: 1;
width: 70%;
margin-left: 15%;
margin-top: 40%;
}
toast-title {
padding-left: 5%;
background-color: #2196f3;
color: white;
padding-top: 2vh;
padding-bottom: 2vh;
border-top-right-radius: 16rpx;
border-top-left-radius: 16rpx;
}
toast-main {
padding-top: 2vh;
padding-bottom: 2vh;
background-color: white;
text-align: center;
}
toast-input {
margin-left: 5%;
margin-right: 5%;
border: 1px solid #ddd;
padding-left: 2vh;
padding-right: 2vh;
padding-top: 1vh;
padding-bottom: 1vh;
}
toast-button {
display: flex;
}
button1 {
width: 50%;
}
button2 {
width: 50%;
}
button1 button {
width: 100%;
background-color: white;
color: red;
border-radius: 0px;
border-bottom-left-radius: 16rpx;
}
button2 button{
width: 100%;
background-color: white;
color: black;
border-radius: 0px;
border-bottom-right-radius: 16rpx;
}
picker {
padding-top: 1vh;
padding-bottom: 1vh;
}
我们可以根据自己的喜欢,对提示框的样式进行改变
5、编写js代码,我们需要实现以下一些基本功能(点击出现d窗,取消不改变数据值,确定进行判断数据值,若为空则不能改变,否则可以改变,并且主页面上的内容要变为相应改变后的内容)
6、给最外层的d窗附上hidden(如图所示),为这个值初始为false,点击按钮后触发事件,改false为true,这样即可点击出现d窗。
7、为取消按钮附上点击事件,与hidden的部分刚好相反即可。
8、为书写文本绑定事件,上述代码中命名为setValue,这个函数我们传入一个event进去,将其打印,我们可以发现在其的detail中有我们刚刚所书写的内容,我们将这个值,传给js中data一个属性,这里我们命名为edit。
9、为确定绑定事件,用thisdataedit将这个值进行判断,若为空,我们用wxshowToast提示用户信息没有填写完整,并且页面不会改变。若不为空,则我们setData一下我们的stuName为这个edit的值,并且重新把hidden的属性值改为false。
10、返回到初始页面我们就可以看到我们自己做得一个提示框,并且具有修改值的功能
mode 属性:
默认值:scaleToFill —- 不保持纵横比例缩放,使的宽高完全拉伸至填满image标签
aspectFit —- 保持纵横比例缩放,使的长边能够完全显示出来,也就说可以完整的显示出来
aspectFill —– 保持纵横比例缩放,只保证的短边能够完全显示出来,也就是说,通常只在水平或垂直方向是完整的,另一个方向将会发生截取
top —- 不缩放,只显示的顶部区域
bottom —- 不缩放,只显示的底部区域
center —- 不缩放,只显示的中间区域
left —- 不缩放,只显示的左边区域
right —– 不缩放,只显示的右边区域
top left —- 不缩放,只显示的左上边区域
top right —- 不缩放,只显示的右上边区域
bottom left —- 不缩放,只显示的左下边区域
bottom right —- 不缩放,只显示的右下边区域
4隐藏NavigationBar
5VM11106:1 Do not have login handler in current page: pages/login/login Please make sure that login handler has been defined in pages/login/login, or pages/login/login has been added into appjson
解决方案:
2调整appjson中Pages里面的页面注册顺序 ;
3检查wxml中bindtap是否在js里面将方法创建。
6switch样式大小调整
大家都知道微信官方提供的switch 能改变color 但是改变大小 常用的width height 不起作用
但是可以这样修改
7input 不沾满屏幕右侧有留白
使用flex布局的时候明明 input style 设置了flex=1 的属性 可是input还是站不满整个屏幕的宽度,右侧有留白,文字被遮挡, 不知道是不是一个bug,
解决方案: 在input外面包一层view style设置flex=1 用于沾满整个屏幕 input用于显示文字
————————————————
1display取值
2float(取值:left,right,none,inherit。)
3clear:该属性指出不允许有浮动对象的边。(取值:left,right,both,none)
4visibility:是否显示对象(取值:visible,hidden,collapse。)
5overflow:处理溢出内容的方式。(取值:visible,hidden,scroll,auto。)
其他属性:
微信小程序
开发文档,相关文章:
微信小程序
action-sheet
微信小程序
modal
微信小程序
toast
微信小程序
loading
微信小程序
loading
属性名
类型
默认值
说明
hidden
Boolean
false
是否隐藏
示例代码:
<view
class="body-view">
<loading
hidden="{{hidden}}">
加载中
</loading>
<button
type="default"
bindtap="loadingTap">点击d出loading</button>
</view>
Page({
data:
{
hidden:
true
},
loadingTap:
function(){
thissetData({
hidden:
false
});
var
that
=
this;
setTimeout(function(){
thatsetData({
hidden:
true
});
thatupdate();
},
3000);
}
})
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
首先配置appjson文件配置相应路径:编译后生成相应文件夹、及文件夹内的4个文件,一个文件夹即一个页面。;
所有的js方法都是用bindtap(点击事件)调用的。例:搜索(点击搜索调用a方法)Input文本框的属性:hidden="{{对应js里data中的内容}}。例:hidden="{{!inputShowed}}( input中的内容不显示) hidden="{{inputShowed}}(显示input中的内容)示例1:先做一个最简单的文本框:在搜索框内输入想要搜索的内容,点击搜索就可以直接获取你想要的内容。
这是一个最简单的搜索框,点击搜索按钮调用接口完成搜索。基础代码如下:wxml
<view> <view> <view class="weui-search-bar"> <view class="weui-search-bar__form"> <!-- 搜索框 --> <view class="weui-search-bar__box"> <icon class="weui-icon-search_in-box" type="search" size="14"></icon> <input type="text" class="weui-search-bar__input" placeholder="请输入搜索内容"/> </view> </view> <!-- 搜索按钮,调用搜索查询方法 --> <view class="weui-search-bar__cancel-btn" bindtap='方法名a'>搜索</view>
在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。即wx:for指令用于循环数组数据,生成组件。
循环出来的每一项通过item返回,每一项对应的索引,通过index返回。
wx:key="",设置每一项唯一的标识。循环列表时,添加wx:key的好处是,将来列表发生变化时重新渲染列表的损耗为更低。
使用 wx:for-item 可以指定数组当前元素的变量名,使用 wx:for-index 可以指定数组当前下标的变量名:
条件渲染可以使用 wx:if 或 hidden 。
一般来说,wx:if 有更高的切换消耗而 hidden 有更高的初始渲染消耗。因此,如果需要频繁切换的情景下,用 hidden 更好;如果在运行时条件不大可能改变,则 wx:if 较好。
wx:if用于条件渲染:条件为真生成里面的内容,条件为假不会生成里面的内容。(每次重新生成内容)
也可以用 wx:elif 和 wx:else 来添加一个 else 块。
hidden用于条件渲染:条件为真隐藏里面的内容,条件为假显示里面的内容。(每次切换样式)
在appjson文件中添加tabBar节点。tabBar是小程序客户端底部或顶部tab栏的实现。
color: tab上的文字默认颜色,仅支持十六进制颜色。
selectedColor: tab上的文字选中时的颜色,仅支持十六进制颜色。
backgroundColor: tab的背景色,仅支持十六进制颜色。
borderStyle: tabbar上边框的颜色, 仅支持 black / white。
position: tabBar的位置,默认值是: bottom,仅支持 bottom / top。当 position 为 top 时,不显示 icon。
custom: 自定义tabBar。
list是一个数组,它定义了tab的列表。只能配置最少2个、最多5个tab。
pagePath: 页面路径,必须在 pages 中先定义。
text: tab 上按钮文字。
iconPath: 路径,icon 大小限制为 40kb,建议尺寸为 81px 81px,不支持网络。
selectedIconPath: 选中时的路径,icon 大小限制为 40kb,建议尺寸为 81px 81px,不支持网络。
跳转到普通页,可以直接通过返回按钮返回。
navigateTo()方法,用于跳转普通页面。可以直接通过返回按钮返回。
页面js文件中添加方法:
redirectTo()方法,关闭当前页面再跳转到指定页,不能通过返回按钮返回页面。该方法不能用于跳转tabBar页面。
页面js文件中添加方法:
跳转到tabBar页面,通过tabBar按钮返回。
如果要使用navigator组件跳转tabBar页面,需要设置open-type="switchTab"。
switchTab()方法,用于跳转tabBar页面。
页面js文件中添加方法:
以上就是关于微信小程序如何使用FillText翻转字体全部的内容,包括:微信小程序如何使用FillText翻转字体、微信小程序 默认打开前置摄像头,IOS显示问题、微信小程序显示打字的叫什么等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)