前端技术
HTML
CSS
Javascript
前端框架和UI库
VUE
ReactJS
AngularJS
JQuery
NodeJS
JSON
Element-UI
Bootstrap
Material UI
服务端和客户端
Java
Python
PHP
Golang
Scala
Kotlin
Groovy
Ruby
Lua
.net
c#
c++
后端WEB和工程框架
SpringBoot
SpringCloud
Struts2
MyBatis
Hibernate
Tornado
Beego
Go-Spring
Go Gin
Go Iris
Dubbo
HessianRPC
Maven
Gradle
数据库
MySQL
Oracle
Mongo
中间件与web容器
Redis
MemCache
Etcd
Cassandra
Kafka
RabbitMQ
RocketMQ
ActiveMQ
Nacos
Consul
Tomcat
Nginx
Netty
大数据技术
Hive
Impala
ClickHouse
DorisDB
Greenplum
PostgreSQL
HBase
Kylin
Hadoop
Apache Pig
ZooKeeper
SeaTunnel
Sqoop
Datax
Flink
Spark
Mahout
数据搜索与日志
ElasticSearch
Apache Lucene
Apache Solr
Kibana
Logstash
数据可视化与OLAP
Apache Atlas
Superset
Saiku
Tesseract
系统与容器
Linux
Shell
Docker
Kubernetes
[控件拖拽与代码关联机制]的搜索结果
这里是文章列表。热门标签的颜色随机变换,标签颜色没有特殊含义。
点击某个标签可搜索标签相关的文章。
点击某个标签可搜索标签相关的文章。
JQuery
...需要为所有的单选按钮关联一个单击动作(click event)。我们可以使用下面的代码来完成: $('input[type="radio"]').click(function() { // 单击动作的应对代码 }); 上面的代码将为页面上所有类型为“radio”的input元素关联一个单击动作。当用户单击任何一个单选按钮时,代码块中的代码将被执行。 接下来,我们可以使用jQuery的选择器来获取选中的单选按钮的值。我们可以使用下面的代码完成: var selectedValue = $('input[name="radioButtonName"]:checked').val(); 上面的代码将获取名称为“radioButtonName”的所有单选按钮中当前选中的值。 使用这些代码,我们可以操纵页面上的单选按钮激发动作。例如,我们可以使用选中的值来更新页面上的其他元素,或者使用它来向服务器发送提交请求。
2023-02-15 20:20:10
286
软件工程师
VUE
...e> 在上面的代码中,我们使用Vue.js的v-for命令展现Sku列表,并使用v-model命令关联选择的状态。当用户勾选或取消勾选选项时,通过@change事件启动onSkuSelected方法来处理选择状态。 除了Sku选择器,Vue.js还可以用于完成许多其他的功能,例如页面展现、表单验证、事件处理等。因此,Vue.js已经成为许多开发者选择的第一框架。
2023-05-19 22:11:19
101
算法侠
Element-UI
...于表单处理与数据绑定机制的最新动态和实践。近期,Vue 3.x版本推出Composition API,为复杂数据结构下的表单控件绑定提供了更为灵活且强大的解决方案。通过setup函数以及ref、reactive等API,开发者能够更深入地控制数据流,实现对嵌套对象或数组内字段的精细管理。 例如,在Vue 3的项目中,我们可以利用toRefs或flatMap等工具函数,将复杂的数据结构扁平化处理,便于在el-form-item中直接引用深层属性进行双向绑定。同时,借助于新的验证库如Vuelidate 2,可以更直观地对这些深度嵌套字段执行验证规则,显著提升开发效率和代码可读性。 另外,Element-UI也在持续更新和完善其表单组件功能,以适应更多复杂的业务场景需求。例如,近期发布的Element Plus作为Element-UI的Vue 3版本,不仅优化了原有功能,还在表单组件上引入了全新的设计模式和API接口,让深度数据绑定变得更加得心应手。 综上所述,无论是在框架层面的Vue.js新特性探索,还是在UI库层面的Element-UI/Element Plus功能升级,都为前端开发者应对复杂表单场景提供了有力支持。与时俱进地掌握这些技术和实践,有助于我们在实际项目中更好地实现表单数据的深度绑定与验证,提升用户体验并保证代码质量。
2023-08-03 22:37:41
468
笑傲江湖_
转载文章
...Form文件,并通过拖拽控件自动生成对应的Java类属性。 JavaFX , JavaFX是一个基于Java的高性能RIA(Rich Internet Application)客户端开发框架,用于构建桌面、Web以及移动设备上的富媒体应用程序。相较于Swing,JavaFX提供更现代化的界面外观和用户体验,支持CSS样式、3D图形渲染、动画等功能。文中提及JavaFX作为Swing之外的另一种GUI开发工具包,同样可以实现图形界面的快速开发与集成。 ScrcpyController , ScrcpyController是在特定项目或插件中实现的Java类,负责展示实际的应用界面。在本文的上下文中,它利用了Java GUI开发技术(可能是Swing或JavaFX)来创建一个显示手机屏幕镜像或控制功能的界面。这个类与ScrcpyToolWindowFactory和配置相关的工厂类协同工作,共同实现了插件化工具窗口的功能展现与交互逻辑。 ToolWindow , 在IntelliJ IDEA或其他集成开发环境(IDE)中,ToolWindow是一种特殊的窗口类型,通常位于主编辑区的侧面或底部,用以提供辅助功能或工具集。例如,在本文提到的场景下,ScrcpyController界面就是通过ScrcpyToolWindowFactory整合到IDEA的ToolWindow区域进行展示,方便开发者在编写代码的同时操作相关工具。 工厂类(Factory Class) , 在面向对象编程中,工厂类是一种设计模式,它封装了对象的创建过程,使得系统中的其他部分无需了解对象的具体创建细节。在本文所描述的Java GUI开发过程中,ScrcpyToolWindowFactory和ScrcpyControllerConfigurable都是工厂类的例子,它们分别负责将界面组件加载至ToolWindow中以及设置界面与实际业务逻辑的绑定,隐藏了具体的创建步骤,提高了代码的可维护性和复用性。
2023-05-01 10:38:51
437
转载
AngularJS
...与视图之间的自动同步机制。在该机制下,当模型(Model)的数据发生变化时,视图(View)会立即更新以反映这些变化;反之,如果用户在界面上修改了数据,这些改动也会同步回模型中。这种实时的、相互关联的数据流动使得开发者无需手动操作DOM来更新界面,极大地简化了前端开发流程,提高了开发效率。 观察者模式 , 观察者模式是一种设计模式,用于实现实体对象(即“主题”或“被观察者”)与依赖于它的多个对象(即“观察者”)之间的解耦。在AngularJS的数据绑定实现中,观察者模式扮演了关键角色。当模型数据发生变化时,“主题”(模型)会通知所有注册过的“观察者”(例如指令或服务),然后“观察者”们根据接收到的通知执行相应的操作,如更新视图元素。这样就实现了数据变动与视图更新的自动化处理。 ngModel指令 , ngModel是AngularJS中一个重要的内建指令,主要用于表单控件与应用程序数据模型之间的双向数据绑定。通过在HTML元素上添加ngModel指令,可以将表单输入控件(如input、select等)与JavaScript变量或对象属性建立联系。每当表单控件值发生变化时,ngModel指令会自动更新相关联的模型数据;而模型数据的变化也会立刻反映到对应的表单控件上,确保视图和模型始终保持一致。
2024-01-20 13:07:16
414
风中飘零-t
转载文章
...添加到 Java 源代码的语法元数据。类、方法、变量、参数、包都可以被注解,可用来将信息元数据与程序元素进行关联。目前很多开源库都使用到了注解,最熟悉的ButtonKnife中的@ViewInject(R.id.x)就可以替代findViewId,不懂这一块技术的同学第一眼看上去肯定会一脸懵逼,下面会手把手带大家写出ButtonKnife的注解使用。使用注解可以简化代码,提高开发效率。本文简单介绍下注解的使用,并对几个 Android 开源库的注解使用原理进行简析。 1、作用 标记,用于告诉编译器一些信息 ; 编译时动态处理,如动态生成代码 ; 运行时动态处理,如得到注解信息。 2、分类 标准 Annotation, 包括 Override, Deprecated, SuppressWarnings。也都是Java自带的几个 Annotation,上面三个分别表示重写函数,不鼓励使用(有更好方式、使用有风险或已不在维护),忽略某项 Warning; 元 Annotation ,@Retention, @Target, @Inherited, @Documented。元 Annotation 是指用来定义 Annotation 的 Annotation,在后面 Annotation 自定义部分会详细介绍含义; 自定义 Annotation , 表示自己根据需要定义的 Annotation,定义时需要用到上面的元 Annotation 这里只是一种分类而已,也可以根据作用域分为源码时、编译时、运行时 Annotation。通过 @interface 定义,注解名即为自定义注解名。 一、自定义注解 例如,注解@MethodInfo: @Documented@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.METHOD)@Inheritedpublic @interface MethodInfo {String author() default "annotation@gmail.com";String date();int version() default 1;} 使用到了元Annotation: @Documented 是否会保存到 Javadoc 文档中 ; @Retention 保留时间,可选值 SOURCE(源码时),CLASS(编译时),RUNTIME(运行时),默认为 CLASS,值为 SOURCE 大都为 Mark Annotation,这类 Annotation 大都用来校验,比如 Override, Deprecated, SuppressWarnings ; @Target 用来指定修饰的元素,如 CONSTRUCTOR:用于描述构造器、FIELD:用于描述域、LOCAL_VARIABLE:用于描述局部变量、METHOD:用于描述方法、PACKAGE:用于描述包、PARAMETER:用于描述参数、TYPE:用于描述类、接口(包括注解类型) 或enum声明。 @Inherited 是否可以被继承,默认为 false。 注解的参数名为注解类的方法名,且: 所有方法没有方法体,没有参数没有修饰符,实际只允许 public & abstract 修饰符,默认为 public ,不允许抛异常; 方法返回值只能是基本类型,String, Class, annotation, enumeration 或者是他们的一维数组; 若只有一个默认属性,可直接用 value() 函数。一个属性都没有表示该 Annotation 为 Mark Annotation。 public class App {@MethodInfo(author = “annotation.cn+android@gmail.com”,date = "2011/01/11",version = 2)public String getAppName() {return "appname";} } 调用自定义MethodInfo 的示例,这里注解的作用实际是给方法添加相关信息: author、date、version 。 二、实战注解Butter Knife 首先,先定义一个ViewInject注解。 public @interface ViewInject { int value() default -1;} 紧接着,为刚自定义注解添加元注解。 @Target({ElementType.FIELD, ElementType.PARAMETER, ElementType.METHOD})@Retention(RetentionPolicy.RUNTIME)public @interface ViewInject {int value() default -1;} 再定义一个注解LayoutInject @Target(ElementType.TYPE)@Retention(RetentionPolicy.RUNTIME)public @interface LayoutInject {int value() default -1;} 定义一个基础的Activity。 package cn.wsy.myretrofit.annotation;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import android.util.Log;import java.lang.reflect.Field;public class InjectActivity extends AppCompatActivity {private int mLayoutId = -1;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);displayInjectLayout();displayInjectView();}/ 解析注解view id/private void displayInjectView() {if (mLayoutId <=0){return ;}Class<?> clazz = this.getClass();Field[] fields = clazz.getDeclaredFields();//获得声明的成员变量for (Field field : fields) {//判断是否有注解try {if (field.getAnnotations() != null) {if (field.isAnnotationPresent(ViewInject.class)) {//如果属于这个注解//为这个控件设置属性field.setAccessible(true);//允许修改反射属性ViewInject inject = field.getAnnotation(ViewInject.class);field.set(this, this.findViewById(inject.value()));} }} catch (Exception e) {Log.e("wusy", "not found view id!");} }}/ 注解布局Layout id/private void displayInjectLayout() {Class<?> clazz = this.getClass();if (clazz.getAnnotations() != null){if (clazz.isAnnotationPresent(LayouyInject.class)){LayouyInject inject = clazz.getAnnotation(LayouyInject.class);mLayoutId = inject.value();setContentView(mLayoutId);} }} } 首先,这里是根据映射实现设置控件的注解,java中使用反射的机制效率性能并不高。这里只是举例子实现注解。ButterKnife官方申明不是通过反射机制,因此效率会高点。 package cn.wsy.myretrofit;import android.os.Bundle;import android.widget.TextView;import cn.wsy.myretrofit.annotation.InjectActivity;import cn.wsy.myretrofit.annotation.LayouyInject;import cn.wsy.myretrofit.annotation.ViewInject;@LayoutInject(R.layout.activity_main)public class MainActivity extends InjectActivity {@ViewInject(R.id.textview)private TextView textView;@ViewInject(R.id.textview1)private TextView textview1;@ViewInject(R.id.textview2)private TextView textview2;@ViewInject(R.id.textview3)private TextView textview3;@ViewInject(R.id.textview4)private TextView textview4;@ViewInject(R.id.textview5)private TextView textview5;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//设置属性textView.setText("OK");textview1.setText("OK1");textview2.setText("OK2");textview3.setText("OK3");textview4.setText("OK4");textview5.setText("OK5");} } 上面直接继承InjectActivity即可,文章上面也有说过:LayouyInject为什么作用域是TYPE,首先在加载view的时候,肯定是优先加载布局啊,ButterKnife也不例外。因此选择作用域在描述类,并且存在运行时。 二、解析Annotation原理 1、运行时 Annotation 解析 (1) 运行时 Annotation 指 @Retention 为 RUNTIME 的 Annotation,可手动调用下面常用 API 解析 method.getAnnotation(AnnotationName.class);method.getAnnotations();method.isAnnotationPresent(AnnotationName.class); 其他 @Target 如 Field,Class 方法类似 。 getAnnotation(AnnotationName.class) 表示得到该 Target 某个 Annotation 的信息,一个 Target 可以被多个 Annotation 修饰; getAnnotations() 则表示得到该 Target 所有 Annotation ; isAnnotationPresent(AnnotationName.class) 表示该 Target 是否被某个 Annotation 修饰; (2) 解析示例如下: public static void main(String[] args) {try {Class cls = Class.forName("cn.trinea.java.test.annotation.App");for (Method method : cls.getMethods()) {MethodInfo methodInfo = method.getAnnotation(MethodInfo.class);if (methodInfo != null) {System.out.println("method name:" + method.getName());System.out.println("method author:" + methodInfo.author());System.out.println("method version:" + methodInfo.version());System.out.println("method date:" + methodInfo.date());} }} catch (ClassNotFoundException e) {e.printStackTrace();} } 以之前自定义的 MethodInfo 为例,利用 Target(这里是 Method)getAnnotation 函数得到 Annotation 信息,然后就可以调用 Annotation 的方法得到响应属性值 。 2、编译时 Annotation 解析 (1) 编译时 Annotation 指 @Retention 为 CLASS 的 Annotation,甴 apt(Annotation Processing Tool) 解析自动解析。 使用方法: 自定义类集成自 AbstractProcessor; 重写其中的 process 函数 这块很多同学不理解,实际是 apt(Annotation Processing Tool) 在编译时自动查找所有继承自 AbstractProcessor 的类,然后调用他们的 process 方法去处理。 (2) 假设之前自定义的 MethodInfo 的 @Retention 为 CLASS,解析示例如下: @SupportedAnnotationTypes({ "cn.trinea.java.test.annotation.MethodInfo" })public class MethodInfoProcessor extends AbstractProcessor {@Overridepublic boolean process(Set<? extends TypeElement> annotations, RoundEnvironment env) {HashMap<String, String> map = new HashMap<String, String>();for (TypeElement te : annotations) {for (Element element : env.getElementsAnnotatedWith(te)) {MethodInfo methodInfo = element.getAnnotation(MethodInfo.class);map.put(element.getEnclosingElement().toString(), methodInfo.author());} }return false;} } SupportedAnnotationTypes 表示这个 Processor 要处理的 Annotation 名字。 process 函数中参数 annotations 表示待处理的 Annotations,参数 env 表示当前或是之前的运行环境 process 函数返回值表示这组 annotations 是否被这个 Processor 接受,如果接受后续子的 rocessor 不会再对这个 Annotations 进行处理 三、几个 Android 开源库 Annotation 原理简析 1、Retrofit (1) 调用 @GET("/users/{username}")User getUser(@Path("username") String username); (2) 定义 @Documented@Target(METHOD)@Retention(RUNTIME)@RestMethod("GET")public @interface GET {String value();} 从定义可看出 Retrofit 的 Get Annotation 是运行时 Annotation,并且只能用于修饰 Method (3) 原理 private void parseMethodAnnotations() {for (Annotation methodAnnotation : method.getAnnotations()) {Class<? extends Annotation> annotationType = methodAnnotation.annotationType();RestMethod methodInfo = null;for (Annotation innerAnnotation : annotationType.getAnnotations()) {if (RestMethod.class == innerAnnotation.annotationType()) {methodInfo = (RestMethod) innerAnnotation;break;} }……} } RestMethodInfo.java 的 parseMethodAnnotations 方法如上,会检查每个方法的每个 Annotation, 看是否被 RestMethod 这个 Annotation 修饰的 Annotation 修饰,这个有点绕,就是是否被 GET、DELETE、POST、PUT、HEAD、PATCH 这些 Annotation 修饰,然后得到 Annotation 信息,在对接口进行动态代理时会掉用到这些 Annotation 信息从而完成调用。 因为 Retrofit 原理设计到动态代理,这里只介绍 Annotation。 2、Butter Knife (1) 调用 @InjectView(R.id.user) EditText username; (2) 定义 @Retention(CLASS) @Target(FIELD)public @interface InjectView {int value();} 可看出 Butter Knife 的 InjectView Annotation 是编译时 Annotation,并且只能用于修饰属性 (3) 原理 @Override public boolean process(Set<? extends TypeElement> elements, RoundEnvironment env) {Map<TypeElement, ViewInjector> targetClassMap = findAndParseTargets(env);for (Map.Entry<TypeElement, ViewInjector> entry : targetClassMap.entrySet()) {TypeElement typeElement = entry.getKey();ViewInjector viewInjector = entry.getValue();try {JavaFileObject jfo = filer.createSourceFile(viewInjector.getFqcn(), typeElement);Writer writer = jfo.openWriter();writer.write(viewInjector.brewJava());writer.flush();writer.close();} catch (IOException e) {error(typeElement, "Unable to write injector for type %s: %s", typeElement, e.getMessage());} }return true;} ButterKnifeProcessor.java 的 process 方法如上,编译时,在此方法中过滤 InjectView 这个 Annotation 到 targetClassMap 后,会根据 targetClassMap 中元素生成不同的 class 文件到最终的 APK 中,然后在运行时调用 ButterKnife.inject(x) 函数时会到之前编译时生成的类中去找。 3、ActiveAndroid (1) 调用 @Column(name = “Name") public String name; (2) 定义 @Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)public @interface Column {……} 可看出 ActiveAndroid 的 Column Annotation 是运行时 Annotation,并且只能用于修饰属性 (3) 原理 Field idField = getIdField(type);mColumnNames.put(idField, mIdName);List<Field> fields = new LinkedList<Field>(ReflectionUtils.getDeclaredColumnFields(type));Collections.reverse(fields);for (Field field : fields) {if (field.isAnnotationPresent(Column.class)) {final Column columnAnnotation = field.getAnnotation(Column.class);String columnName = columnAnnotation.name();if (TextUtils.isEmpty(columnName)) {columnName = field.getName();}mColumnNames.put(field, columnName);} } TableInfo.java 的构造函数如上,运行时,得到所有行信息并存储起来用来构件表信息。 ———————————————————————— 最后一个问题,看看这段代码最后运行结果: public class Person {private int id;private String name;public Person(int id, String name) {this.id = id;this.name = name;}public boolean equals(Person person) {return person.id == id;}public int hashCode() {return id;}public static void main(String[] args) {Set<Person> set = new HashSet<Person>();for (int i = 0; i < 10; i++) {set.add(new Person(i, "Jim"));}System.out.println(set.size());} } 答案:示例代码运行结果应该是 10 而不是 1,这个示例代码程序实际想说明的是标记型注解 Override 的作用,为 equals 方法加上 Override 注解就知道 equals 方法的重载是错误的,参数不对。 本篇文章为转载内容。原文链接:https://blog.csdn.net/csdn_aiyang/article/details/81564408。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-03-28 22:30:35
104
转载
转载文章
...时间去看团队里的所有代码。这种工作方式刚开始的时候会比较吃力。因为我不仅仅只是把问题处理完了就完事,而是非得想把和它相关的周边业务逻辑都挖一遍才甘心。因此,班也没少加,好多个周末我都一个人在公司看代码,做测试。 不过这种方式的好处也是显而易见的,我花了大概一年的时间就熟悉了团队里的各种模块和业务。当有老员工离职的时候,我们领导很惆怅。我告诉他不用担心,这些模块我能顶住。有了前期看代码的积累,确实后来的各种事情处理起来都非常的得心应手。入职一年就顶起了团队里的大梁。 而且我还发现我们公司的客户端软件在启动的时候比较慢,通过主动调研和测试,最后给领导提交了一个客户端启动加速的方案。现在能想起来的方式其中一个技术方式是 DLL 的基地址重定位。 02 入职腾讯 在 2011 年下半年,工作了一年多的时候,感觉广播电视领域整体的盘子还是太小了,当时领头企业的营业额一年也就才十个亿左右。再通过和自己在腾讯的同学交流,还是觉得互联网的空间更大。所以也婉拒了领导给的副组长的提拔挽留,又毅然跳到了北京腾讯。 我是 2011 年 11 月加入腾讯的。在项目上,仍然保持和第一家公司时工作类似的风格,全力以赴。不仅仅局限于完成自己手头的工作,主动做一切可能有价值的事情。其中一件事情就是我发现在当时的项目中,存在很多运营后台的开发需求。每次开发一个后台都得有人力去投入。 后来我就在老大的所开发的一套 PHP 框架的基础上进行改进。实现了只要指定一张 Mysql 数据库中的表,就可以自动生成 bootstrap 样式的管理后台界面。支持列表展示、搜索、删除、批量删除、文本框、时间控件等等一切基础功能。再以后涉及管理后台的功能,只需要在这个基础上改造就行了,人力投入降低了很多,风格也得到了统一。这个工具现在在我们团队内部仍然还在广泛地使用。 还有个故事我也讲过,就是老大分配给我一个图片下载的任务。我不局限于完成完成任务,而且还把文件系统、磁盘工作原理都深入整理了一遍,就是这篇《Linux文件系统十问》 03 转战搜狗 2013 下半年的时候,我第一次感受到了工作岗位的震荡。我还专注解决某一个 bug,花了不少精力都还没查到 bug 的原因。这时候,部门助理突然招呼我们所有人都下楼,在银科腾讯的 Image 印象店集合。在那里,见到了腾讯的总裁 Martin。这还是第一次离大老板只有一米远的距离。 所有人都是一脸困惑,突然把大家召集下来是干嘛呢。原来就在几个小时前,腾讯总办已经和搜狗达成了协议。腾讯收购搜狗的一部分股份,并把我们连人带业务一起注入到了搜狗。 没想到,是老板用一种更牛逼的方式帮我把 bug 给解决了。 14 年 1 月正式到了搜狗以后,我们没有继续做搜索了。而是内部 Transfer 到了另外一个部门。做起了搜狗网址导航、搜狗手机助手、搜狗浏览器等业务。我也是从那个时间点,开始带团队的,也是从那以后慢慢开始从个人贡献者到带团队集体输出的角色的转变。 在搜狗工作的这 7 年的时间里,我仍然也是延续之前的风格。不拘泥于完成工作中的产品需求,以及老大交付的任务。而是主动去探索各种项目中有价值的事情。 比如在手机助手的推广中,我琢磨了新用户的安装流程的各个环节后,找出影响用户安装率提升的关键因素。然后对新版本安装包采用了多种技术方案,将单用户获取成本削减了20%+,这一年下来就是千万级别的成本节约。 我们还主动在手机助手的搜索模块中应用了简单的学习算法。采用了用户协同,标签相似,点击反馈等方法将手机助手的搜索转化率提升了数个百分点。 除了用技术提升业务以外,我还结合工作中的问题进行了很多的深度技术思考。 如有一次我们自己维护了一个线上的redis(当时工程部还没有redis平台,redis服务要业务自己维护)。为了优化性能,我把后端的请求由短连接改成了长连接。虽然看效果性能确实是优化了,但是我的思考并没有停止。我们所有的后端机都会连接这个redis。这样在这个redis实例上可能得有6000多条并发连接存在。我就开始疑惑,Linux 最多能有多少个TCP连接呢,我这 6000 条长连接会不会把这个服务器玩坏? 再比如,我们组的服务器遭遇过几次连接相关的线上问题。其中一次是因为端口紧张而导致 CPU 消耗飙升。后来我又深入研究了一下。 最近,由于 Docker 的广泛应用。底层的网络工作方式已经在悄悄地发生变化了。所以我又开辟了一个网络虚拟化的坑,来一点一点地填。 现在我们的「开发内功修炼」公众号和 Github 就是在作为一个我和大家分享我的技术思考的一个窗口。 04 重回腾讯 时隔 7 年,我又以一种奇特的方式变回了腾讯人的身份。 腾讯再一次收购了搜狗的股份,这一次不再是控股,而是全资。 在离开腾讯的这 7 年多的时间里,腾讯的内部技术工作方式已经发生了翻天覆地的变化。 所以在刚转回腾讯的这一段时间里,我花了大量的精力来熟悉腾讯基于 tRPC 的各种技术生态。除了工作日,也投入了不少周末的精力。 05 再叨叨几句 最后,水文里挤干货,通过我今天的文章我想给大家分享这么几点经验。 第一,是要学会抬头看路,选择一个好的赛道进去。我非常庆幸我当年从广电赛道切换到了互联网,获得了更大的舞台。不过其实我自己在这点上做的也不是特别好,2013年底入职搜狗前拒绝了字节大把期权的offer,要不然我我早就财务自由了。 第二,不要光被动接收领导的指令干活。要主动积极思考项目中哪些地方是待改进的,想到了你就去做。领导都非常喜欢积极主动的员工。我自己也是喜欢招一些能主动思考,积极推进的同学。这些人能创造意外的价值。 第三,工作中除了业务以外还要主动技术的深度思考。毕竟技术仍然是开发的立命之本。在晋升考核的时候,业务数据做的再好也代替不了技术实力的核心位置。把工作中的技术点总结一下,在公司内分享出来。不涉及机密的话在外网分享一下更好。对你自己,对你的团队,都是好事。 技术交流群 最近有很多人问,有没有读者交流群,想知道怎么加入。 最近我创建了一些群,大家可以加入。交流群都是免费的,只需要大家加入之后不要随便发广告,多多交流技术就好了。 目前创建了多个交流群,全国交流群、北上广杭深等各地区交流群、面试交流群、资源共享群等。 有兴趣入群的同学,可长按扫描下方二维码,一定要备注:全国 Or 城市 Or 面试 Or 资源,根据格式备注,可更快被通过且邀请进群。 ▲长按扫描 往期推荐 武大94年博士年薪201万入职华为!学霸日程表曝光,简直降维打击! 腾讯三面:40亿个QQ号码如何去重? 我被开除了。。只因为看了骂公司的帖子 如果你喜欢本文, 请长按二维码,关注 Hollis. 转发至朋友圈,是对我最大的支持。 点个 在看 喜欢是一种感觉 在看是一种支持 ↘↘↘ 本篇文章为转载内容。原文链接:https://blog.csdn.net/hollis_chuang/article/details/121738393。 该文由互联网用户投稿提供,文中观点代表作者本人意见,并不代表本站的立场。 作为信息平台,本站仅提供文章转载服务,并不拥有其所有权,也不对文章内容的真实性、准确性和合法性承担责任。 如发现本文存在侵权、违法、违规或事实不符的情况,请及时联系我们,我们将第一时间进行核实并删除相应内容。
2023-02-06 11:38:24
232
转载
JQuery插件下载
...Query设计的高效拖拽插件,它极大地简化了网页上DOM元素的拖放功能实现。该插件不仅支持基本的元素拖拽操作,还具备高级特性如分组拖拽和自动对齐功能,使得多个关联元素可以作为一个整体进行移动,同时在拖动过程中能够智能地与其他元素吸附或对齐,从而提升用户体验和页面布局的灵活性。通过集成magnet.js到项目中,开发者无需从零开始编写复杂的鼠标事件监听及位置计算代码,只需简单调用插件API,即可轻松赋予页面上的任意元素拖拽功能。其易用性和强大的扩展性深受开发者喜爱,适用于多种场景,包括但不限于网页布局设计、可交互式图表制作以及游戏开发等。这款轻量级插件大大降低了前端开发的复杂度,提升了开发效率与用户界面的动态交互效果。 点我下载 文件大小:99.29 KB 您将下载一个JQuery插件资源包,该资源包内部文件的目录结构如下: 本网站提供JQuery插件下载功能,旨在帮助广大用户在工作学习中提升效率、节约时间。 本网站的下载内容来自于互联网。如您发现任何侵犯您权益的内容,请立即告知我们,我们将迅速响应并删除相关内容。 免责声明:站内所有资源仅供个人学习研究及参考之用,严禁将这些资源应用于商业场景。 若擅自商用导致的一切后果,由使用者承担责任。
2023-05-02 18:34:53
71
本站
VUE
...现Vue框架的响应式机制在CSS类管理上的强大之处。为了进一步掌握这一技术,可关注Vue.js官方文档的最新更新和最佳实践,了解Vue3.0版本中对v-bind:class指令的优化改进。 近期一篇来自Vue.js官方博客的文章“Vue 3中的新特性:Conditional Classes with v-bind:class”详细解读了如何利用新的语法糖更好地实现条件class绑定,并通过实例代码展示了与旧版Vue的差异和优势。此外,文章还探讨了v-bind:class结合模板refs、计算属性以及组合式API(Composition API)等Vue高级特性的应用场景,帮助开发者提升组件化开发效率。 另外,InfoQ的一篇报道《Vue.js在大型项目中的CSS类管理策略》也值得一看,文中不仅回顾了v-bind:class的基本用法,还分享了一些实际项目中如何结合模块化、CSS预处理器等工具进行复杂场景下的class动态管理,这对于面临大规模应用架构挑战的前端开发者具有很高的参考价值。 最后,Vue社区的一些教程如"Vue Conditional Classes: The Complete Guide",提供了大量实战案例,引导读者逐步掌握条件class的各种绑定技巧,包括但不限于基于状态切换、事件驱动、以及与其他Vue指令如v-if、v-for等协同工作的方法,为读者深化Vue技能树提供有力支撑。
2023-07-15 17:19:02
197
键盘勇士
VUE
...通过响应式的数据更新机制确保视图能够实时反映出数据变化。 响应式状态 , 响应式状态是Vue.js实现双向数据绑定的关键特性。当我们在Vue实例的data选项中声明一个对象时,Vue会自动追踪该对象的所有属性变化。这意味着当数据发生变化时,依赖于这些数据的视图组件会自动、及时地更新。例如,在文章中提到的message属性就是一个响应式状态,当其值改变时,Vue会立即更新相应的界面展示。 el选项 , 在Vue实例化过程中,el(Element)是一个关键选项,用于指定Vue实例挂载到哪个DOM元素上。比如代码中的el: app 表示Vue实例将会控制页面上id为 app 的DOM元素,并在其内部渲染应用的视图。这个元素作为Vue实例作用域的根节点,所有在这个实例下定义的模板和数据都会关联到这个元素及它的子元素上,形成一个完整的Vue应用视图结构。
2023-07-11 17:29:32
70
程序媛
VUE
...时器、监听程序、事件关联等执行清理。Vue.js供应了beforeDestroy的生存周期钩子来帮助我们执行这些清理操作。 beforeDestroy() { // 在元件撤销之前执行清理操作 clearInterval(this.timer); window.removeEventListener('大小调整', this.onResize); } 在上面的代码中,我们定义了一个beforeDestroy方法,并在该方法中清除了一个计时器和一个视窗大小调整事件的监听程序。这样,当元件被撤销时,相关的内存就能够被适当地回收。 需要注意的是,在Vue.js 2.x版本中,beforeDestroy钩子被替换为了beforeUnmount,但使用方法和beforeDestroy是类似的。 beforeUnmount() { // 在元件卸载之前执行清理操作 clearInterval(this.timer); window.removeEventListener('大小调整', this.onResize); } 因此,在Vue.js中,使用beforeDestroy或beforeUnmount可以在元件撤销前执行一些清理操作,防止内存泄漏。
2023-12-03 18:12:48
66
逻辑鬼才
AngularJS
...13版本,其中对表单控件和验证机制进行了优化升级,新增了对可访问性规范的严格遵循以及更细致的错误提示,从而帮助开发者更好地处理表单提交行为异常,提高用户体验。同时,Angular Material库也同步更新了一系列UI组件,为表单设计与交互提供了丰富的、符合Material Design规范的选择。 此外,在实际项目中,如何结合最新的前端安全策略来防止XSS攻击和CSRF攻击也是表单提交时不可忽视的一环。开发者应确保在表单数据提交前后进行有效的验证与清理,并合理利用Angular提供的依赖注入和HTTP服务模块来进行安全的数据交互。 综上所述,掌握Angular(包括AngularJS及后续版本)中表单处理的最佳实践,不仅能够有效避免类似ngsubmit异常这样的问题,更能助力开发者构建出高效稳定、安全易用的现代Web应用。
2023-11-13 22:15:25
463
寂静森林-t
Python
...按时作业。 载入关联模块 import schedule import time 设定一个作业 def job(): print("每天按时作业已运行") 设定一个按时器,每日的7:30运行作业 schedule.every().day.at("7:30").do(job) 无限循环来运行按时作业 while True: schedule.run_pending() time.sleep(1) 以上代码中,我们引入了两个库,一个是schedule,另一个是time。schedule是一个Python库,它可以帮助我们进行按时作业的调度。time则是Python内置的时间模块,主要用于线程等待。 我们首先需要设定我们要运行的作业,这里我们简单地打印一句话。接着,我们使用schedule.every().day.at("7:30").do(job)来设定作业的按时运行时间。最后一步,我们通过一个无限循环来持续不断地运行按时作业。 通过以上的代码,我们就可以完成每天按时作业了。如果我们需要运行其他的作业,也可以在job()函数中添加相应的代码。同时,我们也可以通过修改schedule.every().day.at("7:30")来设定运行作业的时间。
2023-01-01 19:28:30
351
软件工程师
JQuery
...构。而连接HTML和关联事件是JQuery中最常用的两个作用之一。 // 运用JQuery连接html代码 var html = ""; $.each(data, function(index, item){ html += " " + item.title + " " + item.content + " "; }); $("container").html(html); 在这个例子中,我们运用JQuery的each方法对数据进行循环,每次循环都会创建一个包含题目和文本的item,并将它们连接到一个大字符串中。最终运用html方法将这个字符串呈现成DOM结构。 // 给动态创建的元素关联事件 $("container").on("click", ".item", function(){ // 点击item时的处理 }); 在这个例子中,我们运用JQuery的on方法给动态创建的元素关联事件。由于item元素是动态创建的,所以我们需要运用事件委托的方式进行关联。这样可以确保关联的元素都可以响应事件。
2023-12-04 09:15:37
395
逻辑鬼才
MySQL
...ySQL是一种普遍的关联式数据库,许多应用软件都要选用它。在特定情境下,你可能需要从异地服务端连接MySQL数据库。本文将向你介绍如何检查MySQL是否支持异地访问。 要检查MySQL是否支持异地访问,需要连接MySQL服务端。然后,选用以下步骤: $ mysql -u用户名 -p密码 Enter password: mysql>use mysql; mysql>SELECT host, user FROM user WHERE host != 'localhost'; 代码中的第一个命令是接入MySQL服务端。将用户名和密码替换为你的登录信息。在输入密码后,你将进入MySQL的终端界面。在此界面下,运行以下步骤: 第1步: use mysql; 上述命令将选用MySQL的自带mysql数据库。 第2步: SELECT host, user FROM user WHERE host != 'localhost'; 上述命令将检索MySQL的user表,它包括所有用户的信息。在显示结果中,你将看到近似以下的结果: +-----------+------------------+ | host | user | +-----------+------------------+ | localhost | root | | 127.0.0.1 | root | | ::1 | root | | % | your_username | +-----------+------------------+ 一般情况下,你会看到像上面那个表格数据的显示结果。这意味着你可以从任何异地服务端连接MySQL服务端。 如果host列只有'localhost',这意味着MySQL不支持从异地服务端连接。你可以选用以下命令修改这个设置: GRANT ALL PRIVILEGES ON . TO 'your_username'@'%' IDENTIFIED BY 'your_password' WITH GRANT OPTION; 上述命令将your_username赋予连接MySQL服务端的所有许可权。请将your_username和your_password替换为你自己的登录信息。 最后,你可以重复运行之前的命令,确保host列包括'%'。
2023-12-17 16:15:36
63
数据库专家
HTML
...动是指三个或以上相互关联的下拉框组件,用户在选择一个下拉框中的选项后,会触发其他下拉框内容的动态更新,形成逐级筛选的效果。例如在本文中,省份、城市和县区三个下拉框就构成了三级联动,当用户选定某个省份时,对应的市级和县级下拉框会自动加载并显示该省份下的城市和县区列表。 onChange事件 , onChange是HTML元素的一个常见JavaScript事件,它会在元素(如input、select等)内容发生改变且失去焦点时触发。在本文的上下文中,省份下拉框通过设置onChange属性,并绑定changeProvince函数,使得当用户更改省份选项时,能实时调用该函数来更新后续的城市和县区下拉框选项。 Option对象 , 在JavaScript中,Option对象代表HTML select元素中的一个选项。在创建或修改下拉菜单选项时,可以使用new Option()构造函数创建一个新的Option对象实例。例如,在文章的代码示例中,我们通过add方法将新的Option对象添加到城市或县区下拉框的options集合中,其中Option对象的两个参数分别指定了选项的显示文本和对应的value值,这样就能实现根据省份选择动态生成城市和县区选项的功能。
2023-11-21 16:03:03
523
软件工程师
PHP
...,并将结果存储在一个关联数组中。 php function countRecommendedUsers($users) { $countMap = array(); foreach ($users as $user) { if (!isset($countMap[$user->id])) { $countMap[$user->id] = 0; } $countMap[$user->id] += count($user->recommendedUsers); } return $countMap; } 最后,我们可以调用这个函数,获取每个用户的推荐人数,并打印出来。 php $userList = array( new User(1, 'Alice', array('Bob')), new User(2, 'Bob', array('Charlie')), new User(3, 'Charlie', array()) ); $countMap = countRecommendedUsers($userList); foreach ($countMap as $userId => $count) { echo "User ID: {$userId}, Recommended Users: {$count}\n"; } 四、总结 通过上述步骤,我们成功地实现了在输出用户列表的同时,统计并输出每个用户推荐用户的人数的功能。这个过程既涉及到面向对象编程的知识,也涉及到了数组操作的知识。理解这些知识,对于学习和使用PHP都是非常重要的。 在这个过程中,我们还思考了一些问题,比如如何设计和使用类,如何编写高效的代码等。这些可都是我们在实际编程开发过程中,经常会碰到的头疼问题,也是我们不得不持续学习、不断摸索、努力攻破的难关!希望这篇文章能对你有所帮助,也希望你能从中得到一些启发。
2023-06-30 08:23:33
68
素颜如水_t
Java
...a编程语言中输入输出机制的基础上,进一步探索现代软件开发领域对I/O处理的新需求与挑战。近期,随着云原生和大数据时代的来临,Java生态体系也在不断优化和完善其输入输出功能的性能和灵活性。 例如,Java 15引入了全新的文本块(Text Blocks)特性,极大地简化了多行字符串的输入输出处理,特别是对于JSON、XML等格式化数据的读写操作,程序员可以更加便捷地编写和输出复杂结构的数据内容,提高了代码可读性和维护性。 同时,为应对大规模并发场景下的I/O瓶颈问题,Java NIO(非阻塞I/O)框架的应用愈发广泛。通过Channel和Selector机制,Java能够实现高效的数据读写,尤其适用于网络通信、文件系统交互等高吞吐量场景。 此外,随着函数式编程范式的流行,Java 8及后续版本推出的Stream API提供了流畅且易于并行化的数据处理能力,极大提升了集合类数据的输入输出效率,特别是在数据过滤、转换、聚合等操作上,体现了现代化编程语言对输入输出处理的更高层次抽象。 综上所述,Java输入输出功能已从基础的控制台输入输出发展到支持高级数据流处理、高性能并发I/O以及更友好的字符串表示形式,未来将随着技术趋势持续演进,以满足日益复杂的软件工程应用场景需求。开发者应当关注这些最新进展,以便在实际项目中充分利用Java提供的强大工具和框架,提升程序效能和用户体验。
2023-12-24 11:21:23
397
数据库专家
转载文章
...T中母版页嵌套结构及控件访问方法后,我们发现随着Web开发技术的演进,现代框架如ASP.NET Core提供了更为灵活和高效的页面布局与组件化管理机制。例如,在ASP.NET Core MVC中, Razor视图组件(View Components)被广泛用于实现可重用的UI逻辑块,它在某种程度上可以视为母版页功能的增强版,尤其是在处理复杂嵌套场景时。 近期一篇名为“Exploring View Components in ASP.NET Core: A Modern Alternative to Nested Master Pages”的文章深入探讨了这一话题。作者通过实例分析了如何利用Razor视图组件替代传统的多层嵌套母版页,以更简洁、模块化的代码来组织和复用页面内容。该文章还强调了使用视图组件所带来的性能优势以及对现代化前端开发实践的良好支持,如服务器端渲染与前端框架(如React或Angular)的集成。 此外,针对ASP.NET传统项目中FindControl方法的局限性,有开发者提出采用强类型视图模型结合Tag Helpers的方式,使得在处理嵌套布局时能够直接且安全地访问任何层级的控件,从而避免了动态查找可能导致的运行时错误和性能损耗。这种方案在社区内得到了积极反响,并在许多实际项目中得以应用。 综上所述,尽管原始文章讨论了在旧版ASP.NET中访问嵌套母版页控件的方法,但随着技术发展,我们可以转向研究ASP.NET Core中的新型解决方案,这些方案不仅解决了原有问题,还引入了更多优化和便捷特性,有助于提升开发效率和用户体验。对于关注此领域的开发者来说,紧跟最新技术趋势并适时进行技术栈升级,无疑具有极高的实践价值。
2023-11-19 12:06:40
299
转载
VUE
...有快速的双向数据绑定机制和组件化的设计思路,使得开发人员可以快速构建数据驱动的网页应用。MySQL则是一种快速、稳固的关系型数据库,它被广泛用于数据存储和管理,具有开放源代码、可定制和高度可靠性等特点。 在使用Vue开发网页应用时,经常需要从MySQL数据库中读取数据,供前端页面进行呈现或者做其他处理。此时,我们可以通过Vue的组件导入mysql模块,完成与MySQL数据库的连接和数据读取。 import mysql from 'mysql'; export default { data() { return { users: [] } }, mounted() { const connection = mysql.createConnection({ host: 'localhost', user: 'root', password: '123456', database: 'test' }); connection.connect(); connection.query('SELECT FROM users', (error, results, fields) =>{ if (error) throw error; this.users = results; }); connection.end(); } } 在上面的代码中,我们通过npm安装了mysql模块,并在Vue组件中使用了它。首先,我们创建了一个数据库连接connection,并传入数据库的参数。接着,我们执行了一次数据查询,得到了结果results,并将其关联到Vue组件的data中。最后,我们关闭了数据库连接connection。这样就完成了从MySQL数据库中读取数据,并且将其关联至Vue组件中。 总的来说,Vue和MySQL是两个非常重要的前端结构和关系型数据库,在实际开发中经常被使用。通过学习和掌握Vue和MySQL的使用方法,可以让我们更加快速地进行前端开发和数据存储。
2023-11-04 09:39:55
77
数据库专家
Python
...针对每种平台重新编写代码或进行大幅度修改。在Python桌面应用开发中,由于Python语言的跨平台特性,开发者编写的代码可以不经修改地在Windows、Mac OS和Linux等不同操作系统上运行,极大地提高了开发效率和应用的普适性。 GUI编程库(如Tkinter和PyQt) , GUI编程库是提供构建图形用户界面(Graphical User Interface, GUI)功能的程序库。在Python中,Tkinter和PyQt是两种常用的GUI编程库。Tkinter是Python标准库自带的一种简单易用的GUI工具包,提供了各种基本的窗口组件,允许开发者快速创建桌面应用程序界面;而PyQt则是基于Qt框架构建的更为强大的Python绑定库,不仅包含丰富的GUI控件,还支持复杂的窗口部件布局管理以及信号与槽机制,使得开发者能够设计出更加现代化且高度定制化的桌面应用。 支持库和模块 , 在Python生态系统中,支持库和模块是指预先编写好的、可供开发者直接调用的功能集合。这些库和模块涵盖了从文件处理、网络通信到数据库操作等各种应用场景,为Python桌面应用的开发提供了便利。通过引用和使用这些预设的库和模块,开发者可以专注于实现应用程序的核心逻辑,不必从零开始编写所有底层代码,从而大大提升了开发效率和代码复用率。例如,在Python中,requests库用于处理HTTP请求,numpy库则广泛应用于科学计算和数据分析领域,这些都是Python支持库和模块的具体实例。
2023-09-13 12:11:56
294
算法侠
MySQL
...ySQL是一种开放源代码的关联型资料库管理系统,可以用于保存和管理业务数据。下面是选用MySQL保存业务数据的基础流程: 1. 建立资料库 CREATE DATABASE system_data; 2. 建立表结构 USE system_data; CREATE TABLE user( id INT 不能为空 NULL AUTO_INCREMENT, username 变长字符串(50) 不能为空 NULL, password 变长字符串(50) 不能为空 NULL, email 变长字符串(50), phone 变长字符串(20), PRIMARY KEY (id) ); 3. 添加数据 INSERT INTO user(username, password, email, phone) VALUES('user1', '123456', 'user1@email.com', '123456'); INSERT INTO user(username, password, email) VALUES('user2', 'abc123', 'user2@email.com'); 4. 检索数据 选取 从 user; 选取 username, email 从 user; 选取 从 user 在…条件下 username = 'user1'; 选取 COUNT() 从 user; 5. 修改数据 UPDATE user 设定 password = 'newpassword' 在…条件下 id = 1; 6. 删除数据 DELETE 从 user 在…条件下 id = 2; MySQL提供了丰富的功能和灵活的检索语言,可以满足大部分业务数据的保存需求。
2023-01-17 16:44:32
123
程序媛
站内搜索
用于搜索本网站内部文章,支持栏目切换。
知识学习
实践的时候请根据实际情况谨慎操作。
随机学习一条linux命令:
free -m
- 查看系统内存使用情况(单位MB)。
推荐内容
推荐本栏目内的其它文章,看看还有哪些文章让你感兴趣。
2023-04-28
2023-08-09
2023-06-18
2023-04-14
2023-02-18
2023-04-17
2024-01-11
2023-10-03
2023-09-09
2023-06-13
2023-08-07
2023-03-11
历史内容
快速导航到对应月份的历史文章列表。
随便看看
拉到页底了吧,随便看看还有哪些文章你可能感兴趣。
时光飞逝
"流光容易把人抛,红了樱桃,绿了芭蕉。"