美文网首页
2018-01-26 微信小程序特殊效果合集和项目总结、 微信

2018-01-26 微信小程序特殊效果合集和项目总结、 微信

作者: 胡諾 | 来源:发表于2018-01-29 08:58 被阅读0次

    第一组:杨昊 微信小程序特殊效果合集和项目总结

    转载自知乎https://www.zhihu.com/question/50907897,这些文章我看了一下,还不错。

    微信小程序特殊效果合集第一期

    微信小程序特殊效果合集第二期

    微信小程序优秀教程及文章合集第一期

    微信小程序项目总结系列:作者:Tong_T,博客地址:Tong_T的博客 - 博客频道 - CSDN.NET

    微信小程序项目总结《一》序言、准备工作、项目构架

    微信小程序项目总结《二》配置、首页面开发

    微信小程序项目总结《三》阅读首页、阅读详情开发

    微信小程序项目总结《四》电影首页、电影更多开发

    微信小程序项目总结《五》电影首页、电影更多开发

    微信小程序项目总结《六》项目结束和补充总结


    第二组:赵彩凤 微信小程序

    1.手动选择跳转tabbar页面

    wx.switchTab({  
          url: '../b/b'  
    }); 
    
    1. 手动弹框(弹框样式需自定)
       <view class="toast_content_box" wx:if="{{isShowToast}}">
          <view class="toast_content">
            <view class="toast_content_text">
              {{toastText}}
            </view>
          </view>
        </view>
    
     tht.setData({
         count: 1500,
         toastText: '弹出内容’
     });
     tht.showToast();
      //弹框Toast
      showToast: function () {
        var _this = this;
        // toast时间  
        _this.data.count = parseInt(_this.data.count) ? parseInt(_this.data.count) : 3000;
        // 显示toast  
        _this.setData({
          isShowToast: true,
        });
        // 定时器关闭  
        setTimeout(function () {
          _this.setData({
            isShowToast: false
          });
        }, _this.data.count);
      }, 
    
    

    第三组:黄华英 C#中实现对象深拷贝(克隆/复制)的几种方法

    方法一:使用二进制流

    using System;
    using System.IO;
    using System.Runtime.Serialization;
    using System.Runtime.Serialization.Formatters.Binary;
    /// <summary>
    /// 参考 http://www.codeproject.com/KB/tips/SerializedObjectCloner.aspx
    /// </summary>
    public static class ObjectCopier
    {
        public static T Clone<T>(T source)
        {
            if (!typeof(T).IsSerializable)
            {
                throw new ArgumentException("The type must be serializable.", "source");
            }
            if (Object.ReferenceEquals(source, null))
            {
                return default(T);
            }
            IFormatter formatter = new BinaryFormatter();
            Stream stream = new MemoryStream();
            using (stream)
            {
                formatter.Serialize(stream, source);
    stream.Seek(0, SeekOrigin.Begin);
                return (T)formatter.Deserialize(stream);
            }
        }
    }
    

    方法二:使用序列化与反序列化

    public static T CloneJson<T>(this T source)
    {            
        if (Object.ReferenceEquals(source, null))
        {
            return default(T);
        }
        var deserializeSettings = new JsonSerializerSettings {ObjectCreationHandling = ObjectCreationHandling.Replace};
        return JsonConvert.DeserializeObject<T>(JsonConvert.SerializeObject(source), deserializeSettings);
    }
    

    方法三:使用反射

    public static T DeepCopyByReflect<T>(T obj)
    {
        //如果是字符串或值类型则直接返回
        if (obj is string || obj.GetType().IsValueType) return obj;
        object retval = Activator.CreateInstance(obj.GetType());
        FieldInfo[] fields = obj.GetType().GetFields(BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance | BindingFlags.Static);
        foreach (FieldInfo field in fields)
        {
            try { field.SetValue(retval, DeepCopyByReflect(field.GetValue(obj))); }
            catch { }
        }
        return (T)retval;
    }
    

    方法四:使用XML序列化与反序列化

    public static T DeserializeXML<T>(string xmlData) where T:new()
        {
            if (string.IsNullOrEmpty(xmlData))
                return default(T);
            TextReader tr = new StringReader(xmlData);
            T DocItms = new T();
            XmlSerializer xms = new XmlSerializer(DocItms.GetType());
            DocItms = (T)xms.Deserialize(tr);
            return DocItms == null ? default(T) : DocItms;
        }
    

    第四组:王芳 滑动穿透

    在webApp的复合页面中,如果主层或者遮罩层的高度大于屏幕高度,滑动遮罩层时就会引起联动,这就是滑动穿透事件,那么如何解决呢。

    我在网上找了很久,有很多人提供了比较好的思路,可惜目前水平不足,看demo的时候一切顺利,改到自己项目中就总是出问题。

    先马上两篇比较认可的文章,以后水平提高了再做尝试吧:

    1. https://uedsky.com/2016-06/mobile-modal-scroll/
    2. https://segmentfault.com/q/1010000012116913/a-1020000012118068

    后来谷歌了一下,找到了一个用纯css实现的方法,使用之后发现很有效,具体如下:

    1. HTML结构:


    2. css:


    注:fixed四个方向的属性值都设置成0


    第五组:王颢

    有时候在一个窗体中有比较多的RadioButton,它们往往是作为取数据、业务逻辑等操作的条件。

    例如下图例子所示:


    用户选择“全部”则会带出全部符合条件数据、选择了“已审核”则会取出全部符合条件的已经审核过后的数据.......我们一般的处理方法是每个RadioButton控件有一个CheckedChanged事件。如下面代码所示

     private void rdAll_CheckedChanged(object sender, EventArgs e) {
        if (rdAll.Checked) {
            this.gvData.DataSource = GetDataSource("ALL");
        }
    }
    
    private void rdAudit_CheckedChanged(object sender, EventArgs e) {
        if (rdAudit.Checked) {
            this.gvData.DataSource = GetDataSource("Audit");
        }
    }
    
    private void rdNotAudit_CheckedChanged(object sender, EventArgs e) {
        if (rdNotAudit.Checked) {
            this.gvData.DataSource = GetDataSource("NotAudit");
        }
    }
    
    private void rdBilled_CheckedChanged(object sender, EventArgs e) {
        if (rdBilled.Checked) {
            this.gvData.DataSource = GetDataSource("Bill");
        }
    }
    
    private void rdUnBill_CheckedChanged(object sender, EventArgs e) {
        if (rdUnBill.Checked) {
            this.gvData.DataSource = GetDataSource("UnBill");
        }
    }
    

    当窗体的RadioButton控件比价多时,那么放眼望去,代码里面到处都是CheckedChanged事件、简直有如洪水泛滥。

    其实我们可以委托来改进代码、这样可以让代码看起来简洁、逻辑清晰、代码量大量减少(当然这个例子不能够证明)。

    我们把所有RadioButton控件的CheckedChanged事件用同一个事件替换。 如下图所示

      private void RadioBtn_CheckedChanged(object sender, EventArgs e)
            {
                if (!((RadioButton)sender).Checked) return;
    
                string filterValue = string.Empty;
                switch (((RadioButton)sender).Tag.ToString())
                {
                    case "ALL":
                        filterValue = "ALL";
                        break;
                    case "Audit":
                        filterValue = "Audit";
                        break;
                    case "NotAudit":
                        filterValue = "NotAudit";
                        break;
                    case "Bill":
                        filterValue = "Bill";
                        break;
                    case "UnBill":
                        filterValue = "UnBill";
                        break;
                }
                this.gvData.DataSource = GetDataSource(filterValue);
    
            }
    
    dev gridcontrol控件中某列单元格值取值与赋值
    for (int i = 0; i < gridView1.RowCount; i++) {
        decimal qmqty = Convert.ToDecimal(this.gridView1.GetRowCellValue(i, gridView1.Columns["期末数量"]));
        int kunzs = Convert.ToInt32(this.gridView1.GetRowCellValue(i, gridView1.Columns["捆支数"]));
        decimal mperz = Convert.ToDecimal(this.gridView1.GetRowCellValue(i, gridView1.Columns["米每支"]));
        decimal zzl = Convert.ToDecimal(this.gridView1.GetRowCellValue(i, gridView1.Columns["支重量"]));
        if (ckbh == "01") {
            int gdjianshu = Convert.ToInt32(qmqty / kunzs / mperz);
            this.gridView1.SetRowCellValue(i, gridView1.Columns["jianshu"], gdjianshu.ToString());
        } else {
            int xcjianshu = Convert.ToInt32(qmqty / kunzs / zzl);
            this.gridView1.SetRowCellValue(i, gridView1.Columns["jianshu"], xcjianshu.ToString());
        }
    }
    

    相关文章

      网友评论

          本文标题:2018-01-26 微信小程序特殊效果合集和项目总结、 微信

          本文链接:https://www.haomeiwen.com/subject/gqgtzxtx.html