什么是可能的Javascript惯例/模式,以避免React类/组件造成不必要的命名空间污染(What is a possible Javascript convention/pattern to avoid unnecessary namespace pollution with React classes/components)
这似乎是一个相当愚蠢的问题,但就此而言,我一直未能找到明确的答案。
我正在寻找一种最佳实践来存储JavaScript中的变量和帮助函数。 我需要保持本地更新列表,所以我的第一本能是将它存储在全局反应类之外,但显然这是一个坏主意,因为我最终需要添加帮助函数和更多变量以用于我的组件。
import React, { Component } from 'react'; import Select from 'react-select'; const list = ['1', '2', '3'] // is it acceptable to store this here? export class Example extends Component { constructor(props) { super(props); this.state = {}; } render() { return ( <div className="well"> <div className="row"> <div className="col-sm-4"> <h3>Device Type</h3> <Select options={list}/> </div> </div> </div> ) } }
我已经阅读了Javascript中许多不同的设计模式(模块,单例,揭示等等),以避免污染全局命名空间,但我不确定我的最佳选择是什么。
再次,我的问题是,存储变量和帮助程序函数的最佳做法是需要由我的反应组件/类使用,而不必将所有内容都放入全局名称空间中。
编辑
显然,这是一个非常广泛的问题,我假设我会因为问这个问题而感到悲伤。 如果有更好的方法提问,请告诉我。 链接到解决问题的其他资源的链接也会非常有帮助。
评论中有人提到,使用ES6模块已经可以解决JavaScript之前存在的全球污染问题。 在我的课程外面存储帮助函数和变量是否没有任何影响,最终是否可行?
This seems like quite a silly question but to this point I haven't been able to find a clear answer.
I'm looking for essentially a best practice to storing variables and helper functions in JavaScript. I need to keep this list updated locally, so my first instinct is to store it outside the react class globally, but clearly this is a bad idea as I will eventually need to add helper functions and more variables to be used in my component.
import React, { Component } from 'react'; import Select from 'react-select'; const list = ['1', '2', '3'] // is it acceptable to store this here? export class Example extends Component { constructor(props) { super(props); this.state = {}; } render() { return ( <div className="well"> <div className="row"> <div className="col-sm-4"> <h3>Device Type</h3> <Select options={list}/> </div> </div> </div> ) } }
I've read about many different design patterns (module, singleton, revealing, etc...) in Javascript to avoid polluting the global namespace, but I'm not sure what my best option is.
So again, my question is, what's the best practice for storing variables and helper functions that need to be used by my react component/class without just throwing everything into the global namespace.
EDIT
Obviously this is a very broad question and I'm assuming I'll receive some grief for asking it. If there's a better way to ask it please let me know. A link to some other resource that answers the question would also be very helpful.
Someone in the comments mentioned that using ES6 modules already handles the global pollution problems that existed in Javascript before. Is it ultimately okay for me to store helper functions and variables outside my class without any repercussions?
原文:https://stackoverflow.com/questions/48024719
最满意答案
使用
IDataErrorInfo
相同的IDataErrorInfo
这里演示http://codeblitz.wordpress.com/2009/05/08/wpf-validation-made-easy-with-idataerrorinfo/
Use the
IDataErrorInfo
wich is the sameHere a demo http://codeblitz.wordpress.com/2009/05/08/wpf-validation-made-easy-with-idataerrorinfo/
相关问答
更多-
使用IDataErrorInfo相同的IDataErrorInfo 这里演示http://codeblitz.wordpress.com/2009/05/08/wpf-validation-made-easy-with-idataerrorinfo/ Use the IDataErrorInfo wich is the same Here a demo http://codeblitz.wordpress.com/2009/05/08/wpf-validation-made-easy-with-idatae ...
-
很好的解释和你的代码看起来也很不错。 我以我的方式解决了你的问题希望你喜欢它。 只需更改像这样的AddError和RemoveError方法, void AddError(string propertyName, string messageText) { List
errList; if (errors.TryGetValue(propertyName, out errList)) { ... -
//This is your row... more or less. public class GridData : DynamicObject, INotifyDataErrorInfo { private Dictionary
_propertyValues = new Dictionary (); //this object holds your errors. private Dictionary INotifyDataErrorInfo - 控件周围出现意外的红色边框(INotifyDataErrorInfo - unexpected red border around controls)[2023-10-04]
在通过@ canto7的评论提示查看代码并进行更多挖掘之后,我想我现在看到了问题。 对于实体级错误的含义似乎存在一些混淆,例如这个SO问题 。 我使用的INDEI实现(以及我怀疑的许多其他实现)将此解释为“返回每个属性的每个验证错误”。 实际上,我认为实体级错误意味着完全相反 - 它们是未针对特定属性记录的验证错误。 例如,涉及多个属性和/或其他类的一些复杂验证规则。 这一切都归结为您的要求。 仅记录特定于属性的错误可能就足够了,在这种情况下, GetErrors(empty string)应返回null。 ...1.混合不同的错误来源 是的,你可以混合你引用的三种验证: ValidationRules适用于GUI(表面)验证 IDataErrorInfo在视图模型/ b对象上实现。 它适用于更多面向业务的验证 INotifiDataErrorInfo也在视图模型/业务对象上实现。 它增加了给定字段上多个错误的可能性,并且还添加了异步验证(即服务器或线程可能需要时间来回答这个问题)。 最后一个错误来源实际上更长 2.考虑到错误 最困难的是,如果要防止在数据无效时关闭窗口,请考虑不同的错误来源。 必须在GUI绑定中查找 ...有关此主题的stackoverflow有很多问题,但没有可靠的答案。 所以我决定发布我的解决方案作为这个问题的答案。 该问题的上下文是检查“ 用户必须在列表框中选择与可观察集合绑定的一个项目 ”。 第一步, ObservableCollection的item(实体)需要IsSelected属性。 public class ProductDecorator : DecoratorBase{ private string _ProductShortName; privat ... 是否为WPF 4.5 DataGrids打破了INotifyDataErrorInfo(Is INotifyDataErrorInfo broken for WPF 4.5 DataGrids)[2022-09-26]
答案是肯定的。 我和微软开了一张票,他们已经确认代码很好,这是.NET 4.5 DataGrid的一个错误。 这是我们的错误,不是你的。 编辑DataGrid单元格时,DataGrid会丢弃“显示”模板的绑定,并将其替换为“编辑”模板的绑定。 丢弃的绑定应该停止监听INDEI.ErrorsChanged事件。 他们没有(这是错误),但他们不准备再参加活动了。 当事件到达时,发生空引用崩溃。 这将在最终版本中修复。 感谢您查找并报告。 非常大的bug必须等到最终版本。 我们希望它能在下一个版本中得到解决。 T ...更正嵌套属性和INotifyDataErrorInfo的属性名称(Correct property name for nested property and INotifyDataErrorInfo)[2022-02-27]
afaik我会说你必须在SomeType类中为你的属性XXX实现IDataErrorInfo,因为你绑定它。 我在我的项目中这样做,它的工作原理。 afaik i would say you have to implement IDataErrorInfo for your property XXX in your SomeType class because you bind to it. i do this in my projects and it works.AnotherItem INotifyDataErrorInfo必须由拥有绑定属性的对象实现。 AnotherItem INotifyDataErrorInfo must be implemented by object who own's the property to which is bound.在引发ErrorsChanged事件时,INotifyDataErrorInfo.HasErrors属性必须返回true。 否则绑定引擎会忽略错误。 您的HasErrors属性将始终返回false。 发生这种情况是因为您正在检查ErrorMessage类型的项目,但您的字典包含KeyValuePair类型的项目>。 除此之外,计算所有项目是非常无效的。 你应该使用.Any()代替。 顺便说一句,INotifyDataErrorInfo的MSDN文档说明如下: 请注 ... 相关文章
更多- javascript 问题
- Becoming a data scientist
- javascript 基本语法
- JavaScript 事件
- JavaScript 事件
- Spring Data: a new perspective of data operations
- javascript url编码
- 简述STRUTS2 Convention零配置
- POJ 3620 Avoid The Lakes【DFS水题练格式Avoid The Lakes Time Limit: 1000MS Memory Limit: 65536K Total Sub】
- javascript常用对象
最新问答
更多- 您如何使用git diff文件,并将其应用于同一存储库的副本的本地分支?(How do you take a git diff file, and apply it to a local branch that is a copy of the same repository?)
- 将长浮点值剪切为2个小数点并复制到字符数组(Cut Long Float Value to 2 decimal points and copy to Character Array)
- OctoberCMS侧边栏不呈现(OctoberCMS Sidebar not rendering)
- 页面加载后对象是否有资格进行垃圾回收?(Are objects eligible for garbage collection after the page loads?)
- codeigniter中的语言不能按预期工作(language in codeigniter doesn' t work as expected)
- 在计算机拍照在哪里进入
- 使用cin.get()从c ++中的输入流中丢弃不需要的字符(Using cin.get() to discard unwanted characters from the input stream in c++)
- No for循环将在for循环中运行。(No for loop will run inside for loop. Testing for primes)
- 单页应用程序:页面重新加载(Single Page Application: page reload)
- 在循环中选择具有相似模式的列名称(Selecting Column Name With Similar Pattern in a Loop)
- System.StackOverflow错误(System.StackOverflow error)
- KnockoutJS未在嵌套模板上应用beforeRemove和afterAdd(KnockoutJS not applying beforeRemove and afterAdd on nested templates)
- 散列包括方法和/或嵌套属性(Hash include methods and/or nested attributes)
- android - 如何避免使用Samsung RFS文件系统延迟/冻结?(android - how to avoid lag/freezes with Samsung RFS filesystem?)
- TensorFlow:基于索引列表创建新张量(TensorFlow: Create a new tensor based on list of indices)
- 企业安全培训的各项内容
- 错误:RPC失败;(error: RPC failed; curl transfer closed with outstanding read data remaining)
- C#类名中允许哪些字符?(What characters are allowed in C# class name?)
- NumPy:将int64值存储在np.array中并使用dtype float64并将其转换回整数是否安全?(NumPy: Is it safe to store an int64 value in an np.array with dtype float64 and later convert it back to integer?)
- 注销后如何隐藏导航portlet?(How to hide navigation portlet after logout?)
- 将多个行和可变行移动到列(moving multiple and variable rows to columns)
- 提交表单时忽略基础href,而不使用Javascript(ignore base href when submitting form, without using Javascript)
- 对setOnInfoWindowClickListener的意图(Intent on setOnInfoWindowClickListener)
- Angular $资源不会改变方法(Angular $resource doesn't change method)
- 在Angular 5中不是一个函数(is not a function in Angular 5)
- 如何配置Composite C1以将.m和桌面作为同一站点提供服务(How to configure Composite C1 to serve .m and desktop as the same site)
- 不适用:悬停在悬停时:在元素之前[复制](Don't apply :hover when hovering on :before element [duplicate])
- 常见的python rpc和cli接口(Common python rpc and cli interface)
- Mysql DB单个字段匹配多个其他字段(Mysql DB single field matching to multiple other fields)
- 产品页面上的Magento Up出售对齐问题(Magento Up sell alignment issue on the products page)